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SYSTEM FOR NETWORK COMMUNICATION OF IMAGE 
INFORMATION BETWEEN IMAGING DEVICES ACCORDING TO 
MULTIPLE PROTOCOLS 

5 

Field of the Invention 

The present invention relates to imaging systems, and, more particularly, to 
systems for communicating image information between an input imaging device and 
an output imaging device in a network environment. 

10 

Background to the Invention 

An imaging system typically includes an input imaging device that generates 
image information, and an output imaging device that forms a visible representation 
of an image based on the image information. In a medical imaging system, for 

1 5 example, the input imaging device may include a diagnostic device, such as a 

magnetic resonance (MR), computed tomography (CT), conventional radiography 
(X-ray), or ultrasound device Alternatively, the input imaging device may include a 
user interface device, such as a keypad, mouse, or trackball, which is also capable of 
generating medical image information. As a further alternative, the input imaging 

20 device may include an image archival workstation for retrieving archived image 
information. The output imaging device in a medical imaging system typically 
includes a digital laser imager. The laser imager exposes an imaging media in 
response to the image information to form the visible representation 

The image information generated by the input imaging device includes image 

25 data containing digital image values representative of the image, and imaging requests 
specifying operations to be performed by the laser imager. Each of the digital image 
values corresponds to one of a plurality of pixels in the original image, and represents 
an optical density associated with the respective pixel In response to an imaging 
request, the laser imager converts the digital image values to generate laser drive 

30 values used to modulate the intensity of a scanning laser. The laser drive values are 
calculated to produce exposure levels, on the imaging media, necessary to reproduce 
the optical densities associated with the pixels in the original image when the media is 
developed, either by wet chemical processing or dry thermal processing. The laser 
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imager may perform a number of additional operations in response to the imaging 
requests generated by the input imaging device For example, the laser imager may 
manipulate the image data, prior to generating the laser drive values, to produce a 
variety of different format and/or appearance characteristics 
5 The image information processed by the laser imager has a format determined 

by an input protocol associated with the particular input imaging device Medical 
imaging systems typically are capable of handling image information generated 
according to a variety of diverse input protocols An input protocol can be 
characterized as including a network driver protocol, which provides lower-level 
10 communications specifications as to a particular input imaging device, and a network 
interpreter protocol, which determines the format for interpreting image information 
generated by the input imaging device. The number of different input protocols 
results, to some degree, from the various types of input imaging devices presently in 
use, e.g., a magnetic resonance (MR), computed tomography (CT), conventional 
1 5 radiography (X-ray), or ultrasound device, each of which may generate image 

information according to a different protocol. The primary source of different input 
protocols is, however, the existence of a number of modalities, i.e., input imaging 
devices made by different manufacturers and having unique, manufacturer- specific 
input protocols. For example, manufacturers such as Siemens, Toshiba, GE, and 
20 Picker presently make CT-type input imaging devices that provide similar 

functionality, but which generate image information according to different modality- 
specific input protocols 

In addition to the ability to handle multiple input protocols, medical imaging 
systems typically are capable of handling communication of image information to 
25 output imaging devices according to multiple output protocols. Like an input 
protocol, an output protocol can be characterized as including an output driver 
protocol, which determines requirements for communication with a particular output 
imaging device, and an output interpreter protocol, which determines the format for 
translating image information into a form understood by the output imaging device. 
30 Different output protocols primarily result from the availability of laser imaging 

output devices having different sets of functional capabilities The different sets of 
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functional capabilities present varying complexity that can lead to different output 
protocols For example, Imation Enterprise Corp ("Imation"), of Oakdale, 
Minnesota, presently offers laser imagers having different sets of functional 
capabilities referred to as the "831," "952," and "SuperSet" sets, each of which is 
5 associated with a set-specific output protocol 

Existing medical imaging systems presently accommodate multiple input and 
output protocols on an ad-hoc basis by the design of point-to-point hardware and/or 
software interfaces specifically configured for a particular input protocol and a 
particular output protocol. The use of a custom-made interface is extremely 
1 0 inflexible. If communication with a different input imaging device is later required, 
the entire interface must be redesigned to handle the relationship between the new 
input protocol and the old output protocol. A change in the output imaging device 
similarly requires redesign of the interface to handle the relationship between the new 
output protocol and the old input protocol. Unfortunately, redesign of the interface 
15 is a cumbersome task that often requires a significant investment in hardware and/or 
software development time. Even seemingly minor modifications in functionality of 
an input or output imaging device can produce numerous, costly design changes that 
propagate throughout the interface. 

One solution to these problems is described in U. S Patent No. 5,630, 101. 
20 The system described in this patent application adopts an object-oriented, modular 
design in effecting a software-based direct-connect architecture to allow for 
significant flexibility in laser imager communication An interface executive 
instantiates the needed input driver-input interpreter pair and the needed output 
interpreter-output driver pair to create a pipeline so that a particular host modality 
25 can communicate with a particular laser imager Each of the input driver, input 
interpreter, output interpreter and output driver components is a discrete software 
object, or "black box " In this manner, each can be modified or replaced by a new 
object without affecting the performance of the others, or the overall pipeline. For 
example, the input interpreter and driver pair may be specific to a Siemens host 
30 modality, while the output interpreter and output driver pair may be specific to an 
Imation laser imager using the 83 1 protocol. If the latter pair is replaced with a pair 
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specific to an Imation laser imager using the SuperSet protocol, the design of the 
components is such that the input interpreter and driver pair does not also need to be 
replaced 

Although U. S. Patent No. 5,630,101 promotes flexibility in laser imager 
5 architecture, it discloses only a direct-connect, point-to-point architecture For every 
input-output pair, the interface executive must instantiate a separate input driver- 
input interpreter pair and output interpreter-output driver pair. That is, the interface 
executive must create a separate pipeline between each host modality and each laser 
imager. Although not a misgiving in a system having a relatively small number of 
10 host modalities, this can pose a problem in environments where a significant number 
of host modalities communicate with a plurality of different laser imagers. This is 
especially true in a networking environment, in which typically a number of network 
clients all speak the same protocol In such a situation, it is desirable not to have 
redundant a input driver-input interpreter pair for each and every client. Besides the 
15 drainage in resources, this architecture also places excessive overhead on the 
interface executive. 

Thus, there is an increasing demand for even more flexible medical imaging 
systems capable of providing communication between a variety of input and output 
imaging devices having multiple protocols. It is desirable that such medical imaging 
20 systems not only provide flexibility with respect to current protocols, but also be 
capable of adaptation to handle future protocols in a cost-effective manner. There 
also are increasing demands for network communication of image information 
between input and output imaging devices In the medical imaging field, for example, 
the American College of Radiology (ACR) and the National Electrical Manufacturers 
25 Association (NEMA) have formed a joint committee to develop a standard for digital 
imaging and communications in medicine, known as the DICOM protocol The 
DICOM protocol was designed to facilitate connectivity among equipment in the 
medical industry, particularly in view of the movement of hospitals from point-to- 
point environments to network environments. Medical equipment manufacturers 
30 throughout the industry are now beginning to implement the DICOM 

communications protocol. The DICOM protocol sets one standard for network 
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communication of image information. However, other network protocols exist and 
will continue to be created. Thus, protocol translation continues to be necessary in 
network systems. The need for protocol translation in network systems creates 
problems similar to those encountered with point-to-point systems. Specifically, 
5 flexibility and ease of adaptation for multiple protocols continue to be of concern. 
Accordingly, there is a need for a system capable of providing network 
communication of image information between imaging devices according to multiple 
communication protocols 

10 Summary of the Invention 

The present invention is directed to a medical imaging system for 
communicating image information via a network between a plurality of different input 
imaging devices and output imaging devices according to different communication 
protocols. 

1 5 In one embodiment of the invention, a software system for communicating 

medical image information between at least one of a plurality of different input 
imaging devices and at least one of a plurality of different laser imagers via a network 
interface comprises one or more network driver components, one or more network 
interpreter components, one or more output interpreter components, one or more 
20 output driver components, one or more network executive components, and an 
interface executive component- 
Each of the network driver components is configured to receive medical 
image information from one of the input imaging devices via a network interface. 
The medical image information is received according to one of a plurality of different 
25 network driver protocols. Each of the network driver protocols is specifically 
associated with one of the input imaging devices. 

Each of the network interpreter components is configured to generate first 
imaging requests based on the medical image information received by one of the 
network driver components. The first imaging requests are generated according to 
30 one of a plurality of different network interpreter protocols. Each of the network 
interpreter protocols is specifically associated with one of the input imaging devices. 
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Each of the output interpreter components is configured to generate second 
imaging requests based on the first imaging requests generated by one of the network 
interpreter components The second imaging requests are generated according to 
one of a plurality of different output interpreter protocols. Each of the output 
interpreter protocols is specifically associated with one of the laser imagers 

Each of the output driver components is configured to communicate the 
second imaging requests generated by one of the output interpreter components to 
one of the laser imagers The second imaging requests are communicated according 
to one of a plurality of different output driver protocols. Each of the output driver 
protocols is specifically associated with one of the laser imagers. 

Each of the network executive components communicatively interconnects 
one of the network driver components and one of the network interpreter 
components. Furthermore, the interface executive component defines one or more 
network communication pipelines. Each of the pipelines communicatively 
15 interconnects one of the input imaging devices, one of the network executive 

components, one of the output interpreter components, one of the output driver 
components, and one of the laser imagers. 

The present invention provides for a number of advantages in facilitating 
communication between the input imaging devices and the laser imagers Because 
20 the network executive components can each facilitate communication of a number of 
input imaging devices, a separate pipeline is not required for each input imaging 
device, thereby conserving resources. The network executive components also allow 
the present invention to facilitate communication between input imaging devices and 
laser imagers on a network level, as opposed to in a direct-connect manner. 
25 Furthermore, the network executive components are delegated responsibility by the 
interface executive component as to overseeing communication from the input 
imaging devices This frees the interface executive component from itself having to 
take on this responsibility. 

In one embodiment of the present invention the software system is 
30 constructed in both an object-oriented and client-server manner, and employs remote 
procedure calls for facilitating communication among components. This gives the 
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invention the benefit of reusability of the components as new components for 
different protocols are created. Further, this gives the invention the advantage of 
seamless integration of the components, and promotes scalability of the entire 
software system In addition, this gives the present invention the advantage of 
interchangeability of the components. 

Still other and further embodiments, aspects and advantages of the present 
invention will become apparent in the following description and by reference to the 
accompanying drawings. 

Brief Description of the Drawings 

The accompanying drawings are included to provide a further understanding 
of the present invention and are incorporated into and constitute a part of this 
specification. The drawings illustrate embodiments of the present invention and 
together with the description serve to explain the principles of the invention 
FIG. 1 is a functional block diagram of a medical imaging system for 
communication of image information between multiple-protocol imaging devices in a 
network communication environment, in accordance with the present invention; 

FIG. 2 is a functional block diagram of an alternative medical imaging system 
for communication of image information between multiple-protocol imaging devices 
m a network communication environment, in accordance with a further embodiment 
of the present invention; 

FIG. 3 is a functional block diagram illustrating a sub-system of the medical 
imaging system of FIG. 1; 

FIG. 4 is a diagram illustrating the object-oriented protocol hierarchy that 
facilitates interchangeability of the network protocol components, including both the 
network driver component and the network interpreter component; 

Fig 5 is a diagram illustrating the object-oriented protocol hierarchy that 
facilitates interchangeability of the output interpreter component and the output 
driver component; and, 
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FIG 6 is a functional block diagram of a client-server relationship applicable 
to the medical imaging system shown in FIG. 1, in accordance with the present 
invention. 
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Detailed Description of the Drawings 
Overview of the present invention 

The present invention effects a scalable software architecture for 
simultaneously translating multiple medical imaging protocols within a network 
paradigm. Referring to FIG. 1, a functional block diagram of a medical imaging 
system 10 for communication of image information between multiple-protocol 
imaging devices in a network communication environment, in accordance with the 
present invention, is shown. The system 10 includes a plurality of input imaging 
devices in the form of network clients 12, one or more network executive 
components 14, one or more output interface components 16, an output imaging 
15 device 1 8, and an interface executive component 20. Each output interface 

component 16 includes an output interpreter component 22 and an output driver 
component 24. 

As shown in FIG. 1, each of clients 12 communicates with output imaging 
device 18 via a particular pipeline 26 specific to a particular protocol. Thus, so long 

20 as each of clients 1 2 speaks the same one protocol, only one pipeline 26 is needed to 
provide for communication between the clients 12 and output imaging device 18 
Further, if each of clients 12 speaks one or two of two different protocols, then two 
different pipelines are needed; and so on. In this manner, the present invention allows 
for N different pipelines for N different protocols, in which each pipeline is capable of 

25 handling M different clients speaking that particular protocol That is, a separate 
pipeline for each client is not required, but rather only for each different protocol. 

Each pipeline 26 comprises three primary components a network executive 
component 14, an output interpreter component 22 and an output driver component 
24, the latter two of which are paired as a single output interface component 16. 

30 Broadly speaking, the system shown in FIG. 1 is set up in the following manner. For 
every output imaging device 18, the interface executive component 14 creates a 
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separate pipeline 26 for each separate protocol spoken by at least one network client 
1 2 that may communicate with imaging device 1 8. The interface executive 
component 14 accomplishes this by instantiating a network executive component 14 
specific to the protocol spoken by one or more clients 12, and an output interface 
component 16 specific to output imaging device 18, a pair of particular components 
14 and 16 thus making up a particular pipeline 26 This creation of pipelines 26 can 
occur either "on the fly" as clients speaking different protocols enter or leave the 
network of system 10, or can occur when the network is first being initialized. The 
present invention is not limited either way 

Upon establishment of the pipelines 26, a client 1 2 speaks to the output 
imaging device 18 in general terms in the following manner Network executive 
component 14 filters and interprets requests received from client 12 to corresponding 
first requests that output interface component 16 understands. Upon transmission to 
interface component 16, the first requests are further filtered and interpreted, to the 
particular corresponding second requests that output imaging device 18 understands 
In this manner, the present invention takes requests specific to a particular protocol, 
translates them into first requests, and further translates them into second requests 
specific to a particular imaging device. Thus, component 14 and component 16 can 
be changed independent of one another, because both speak to one another via first 
20 requests. Put another way, the implementation of a network executive component 14 
specific to a particular protocol is independent of any imaging device 1 8, while the 
implementation of output interface component 16 is independent of any given 
protocol spoken by a particular client 12. Note as well that this process as described 
is operable in reverse, such that requests from device 1 8 can be sent to client 12. 
25 Th e present invention thus adopts a pipeline model for allowing 

communication between M clients speaking N protocols to an imaging device. The 
interface executive component manages creation of these pipelines. A pipeline is 
created for each particular protocol spoken by at least one of M clients on the 
network Because typically N « M, the present invention conserves resources over 
30 a system in which a separate pipeline is necessary for each client, not each protocol. 
This is a significant advantage of the present invention. 
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Referring now to FIG 2, a functional block diagram of a further embodiment 
of the present invention is shown. Like-numbered elements of FIG. 2 as compared to 
FIG. 1 indicate that the elements are identical, and that description of them in 
conjunction with FIG. 1 applies equally in conjunction with FIG. 2. As an alternative 
to instantiating N full translation pipelines, the interface executive component may be 
configured to instantiate one translation pipeline with N network executive 
components operating independently and in parallel to one another. In this manner, 
N x M clients may be supported without the inefficiency of providing N-l output 
interpreter components and N-l output driver components The system 58 of FIG. 2 
supports N network protocols and N x M network clients with the implementation of 
only one communication pipeline. System 58 includes a plurality of network 
executive components 14 that listen for network clients 12 having particular network 
protocols. The interface executive component 20 communicatively interconnects 
each of network executive components 14 with a single output interpreter 
component 22, a single output driver component 24, and a single output imaging 
device 18 to provide a single communication pipeline with multiple, protocol-specific 
network inputs. 

Thus, the embodiment of the present invention as shown in FIG 2 varies from 
that shown in FIG 1 in that the former embodiment conserves even more resources 
than does the latter. In the case where there is one output imaging device but 
multiple network protocols, the embodiment shown in FIG I wastes some resources 
by providing redundant output interface components 16 for each pipeline 26, which 
are all redundant due to the fact that there is only one output imaging device. This 
redundancy, and corresponding waste of resources, is eliminated by the embodiment 
shown in FIG. 2. In FIG. 2, there is only one pipeline 26, and only one output 
interface component 16, to which each of network executive components 14 is 
coupled. Other than this redundancy reduction, FIG. 2 operates identically to FIG I, 
and description made in conjunction with FIG 1 should be referred to for description 
of FIG. 2. 
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Implementation of the Present Invention 

Referring again to FIG. 1, the network executive components 14, output 
interface components 16, and interface executive component 20 are implemented in 
one embodiment as an object-oriented software system that interfaces with a network 
having network clients 12 and output imaging device 18 The software system may 
be implemented as part of an output imaging device 18, such as a continuous tone 
digital laser imager, or as part of a discrete interface device controlling 
communication of image information between network clients 12 and output imaging 
device 18. 

In one embodiment of the invention, the network comprises a plurality of 
different clients, such as magnetic resonance (MR), computed tomography (CT), 
conventional radiography (X-ray), and ultrasound devices, manufactured by a number 
of different manufacturers, such as Siemens, Toshiba, GE, or Picker. The laser 
imager can be any of a number of different imagers, such as those manufactured by 
Imation and that understand the 83 1, 952, or SuperSet protocols. The laser imager 
may also reside directly on the network, in which case the software system typically 
resides on a hardware card inserted into the laser imager. The card typically 
comprises input/output (10) circuitry, as well as memory such as a ROM or flash 
ROM, which is one type of reprogrammable ROM. The software system resides on 
this memory 

In the alternative, the laser imager does not reside directly on the network, 
and instead is coupled to the network via an intermediary computer that itself resides 
directly on the network. The intermediary computer typically has a random-access 
memory (RAM), a read-only memory (ROM), a central-processing unit (CPU) and a 
storage device, such as a hard disk drive, programmable ROM, or disk drive In this 
case, the software system typically resides on the storage device of the intermediary 
computer, and is copied into RAM and executed therefrom by the CPU. Where the 
storage device is a disk drive or other removable storage device, the software system 
can be stored on the storage medium for insertion into the device. The present 
invention is not, however, limited to any particular hardware implementation 
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The image information generated by the input imaging devices associated 
with network clients 12 includes both requests for imaging operations, and image 
data containing digital image values representative of an image to be handled by 
output imaging device 18. For purposes of this description, pipeline 26 will be 
described as handling communication of image information in the form of imaging 
requests, with image information in the form of digital image values representative of 
the image being communicated by a separate communication path It is within the 
scope of the invention, however, that pipeline 26 could be configured to handle 
communication of image information in the form of both requests for imaging 
operations and image data containing the digital image values 

In a typical medical imaging system, imaging requests include requests to 
initiate an image print job by output imaging device 18, requests to abort a previously 
initiated image print job. requests to define or modify a format of an image to be 
printed, requests to delete a set of image data representative of a previously acquired 
image, and requests to store image data in a particular image location. 
Components of the Invention: Interface Executive Component 

The interface executive component 20 defines one or more ( 1 to N) 
communication pipelines 26. Each communication pipeline 26 communicatively 
interconnects, or "binds," one or more of the M network clients 12, one of network 
executive components 14, one of output interpreter components 22, one of output 
driver components 24, and output imaging device 18 in a bi-directional manner. The 
output imaging device 18 may communicate with any of pipelines 26 on a shared 
basis. Alternatively, a plurality of output imaging devices 18 could be provided, each 
being communicatively interconnected with a particular pipeline 26 

The interface executive component 20 provides for the highest level of 
intelligence within system 1 0 of FIG. 1 It governs and manages the particular 
network components 26 and output interface components 16 needed for clients 12 to 
communicate with device 18. That is, as shown in FIG 1, based on the N different 
protocols spoken by clients 12, the interface executive component 20 instantiates a 
particular pipeline 26 made up of a network executive component 26 and output 
interface component 16. Furthermore, if there are P different output imaging devices 
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(as opposed to just one, as shown in FIG I), then the interface executive component 
instantiates N x P different pipelines, one for every unique imaging device-protocol 
pair This can be accomplished in a separate set-up mode, or "on the fly" as clients 
speaking different protocols enter or leave the network 

Although having the most intelligence of any component within the present 
invention, the interface executive component 20 differs from the interface executive 
component disclosed and described in United States patent application serial no. 
08/343,184 in that it has less intelligence than the interface executive component 
disclosed in that patent application. The interface executive component disclosed and 
described in United States patent application serial no. 08/343,184 instantiates an 
input interface component particular to every client needing to communicate with a 
particular imaging device That is, the interface executive component constructs a 
pipeline on a client-by-client basis. Conversely, the interface executive component of 
the present invention instantiates a network executive component 14 specific to a 
particular protocol, and thereto delegates all responsibility of serving network clients 
Thus, the interface executive component of the present invention constructs a 
pipeline on a protocol-by-protocol basis It therefore has less intelligence in that it 
does not micromanage communications with particular clients as does the interface 
executive component of United States patent application serial no. 08/343,184. That 
is, the latter interface executive component "knows" all details regarding the input 
device, whereas the interface executive component of the present invention simply 
"knows" that there are input devices residing on a network, and delegates 
responsibility for handling implementation of the interface as to the input devices to 
the network executive component 1 4 

The interface executive component 20 defines the structure of pipeline 26 
The pipeline 26 is configured to communicatively interconnect a number of 
components 30, 32 (which are shown in FIG. 3 and, as shown there and as will be 
explained later, are instantiated by network executive component 14), 22 and 24 
having different protocols on a selected basis to provide significant flexibility This 
flexibility provides a medical imaging system 10 capable of achieving communication 
between a variety of different network clients 12 and one or more output imaging 
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devices 1 8 having a variety of different functional capabilities. Thus, interface 
executive component 20 treats each functionally independent component 14, 22 and 
24 as a H black box" with a clearly identified set of responsibilities and a defined 
interface. The interface executive component 20 selects the appropriate series of 
5 black boxes based on the environment, and binds them together with "handles" to 
one another to form the complete pipeline 26. As a further advantage, interface 
executive component 20 in one embodiment is configured to dynamically bind the 
components "on the fly" to form a communication pipeline 26 appropriate for the 
current imaging environment. Moreover, interface executive component 20 is 

10 configured to produce a scalable software architecture having a plurality of 
communication pipelines 26 configured according to different protocols The 
scalable architecture enables output imaging device 1 8 to communicate 
simultaneously with several network clients 12 on a shared basis using the necessary 
protocols, as provided by each pipeline 26. Alternatively, a plurality of output 

15 imaging devices 18 can be provided, each being communicatively interconnected with 
a particular pipeline 26. 

Thus, the interface executive component 20 scales the software architecture 
to match the requirements of the environment, creating as many network executive 
components and pipelines as there are different network protocols. The interface 

20 executive component 20 selectively binds a series of components 1 4, 22 and 24 
having specific protocols necessary to match a particular network client 12, a 
particular output imaging device 18, and the required hardware interfaces. 
Components of the Invention: The Network Executive Components 

The network executive component 14 is responsible for handling all network 

25 clients 12 that communicate via a particular protocol. As shown in FIG 1, a network 
executive component 14 is provided for each particular one of N network protocols 
Thus, network executive component 14 handles multiple network clients 12 
simultaneously. The interface executive component 20 delegates to network 
executive component 14 the responsibility of managing all network-specific services 

30 The interface executive component 20 instantiates a particular network executive 
component 14 for each medical imaging network protocol that will be supported on 
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the network by system 10. If the Picker Networking Protocol is to be supported, for 
example, interface executive component 20 instantiates a network executive 
component 14 capable of serving such a protocol For further example, the interface 
executive component 20 also instantiates another network executive component 
capable of serving the DICOM protocol, if that protocol is to be supported. 

The network executive component 14 governs all objects needed to manage 
network communication. The primary function of network executive component 14 
is to monitor or "listen" at network interface 28 for imaging requests from network 
clients 12 having a particular network protocol When a network client 12 requests 
access to output imaging device 18 via a particular network protocol, network 
executive component 14 spawns a network driver component 30 and a network 
interpreter component 32 appropriate for that protocol, as shown in FIG 3. Further, 
network executive component 14 binds network driver component 30 to network 
interpreter component 32, and then binds network interpreter component 32 to 
1 5 output interpreter component 22 using handle information previously provided by the 
interface executive component 20. The network executive component 14 then 
returns to listening to network interface 28 for new requests sent according to the 
particular network protocol. The network driver component 30 and network 
interpreter component 32 together form a network interface component 33, as is also 
20 shown in FIG. 3. 

The presence of the network executive component in the present invention 
serves as a distinguishing characteristic of the invention over U.S. Patent No 
5,630,101. In U.S. Patent No. 5,630,101, there is no corresponding network 
executive components, but rather there are input interface components. The input 

25 interface component, however, is not an intelligent component as is the network 

executive component of the present invention Rather, an input interface component 
is instantiated by the interface executive for every connection between a particular 
client and the imaging device. Conversely, in the present invention the interface 
executive delegates responsibility for client communication to a network executive 

30 component, which itself instantiates other components as necessary for one or more 
clients speaking a common protocol to communicate with the imaging device. 
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The network executive components thus provide the present invention with 
the advantage of network communication in a resource use-minimizing manner. For 
example, overlaying the system disclosed in U.S. Pat. No. 5,630,101 onto a network 
of clients results in the creation of pipelines for each of the clients However, by 
5 incorporating client communication in an intelligent network executive component 
14, the present invention eliminates the need for the creation of pipelines for each of 
the clients, but rather only calls for the creation of a pipeline for each of the protocols 
via which the clients can communicate Because the number of communication 
protocols is typically far less than the number of clients, this results in a significant 
10 savings in resource use Furthermore, by delegating the responsibility for client 
communication to the network executive component 14. the interface executive 
component 20 is freed from such micromanagement duties, which may otherwise 
overburden the interface executive component 

In one embodiment, network driver and network interpreter components 30 
and 32 as shown in FIG. 3 are instantiated "on the fly" in response to detection by 
network executive component 14 of a network client 12 having a specific protocol at 
network interface 84, thereby conserving the hardware/software resources necessary 
to support such components until needed. This dynamic instantiation of the network 
driver and network interpreter components 30, 32 enables reduction in the amount of 
system overhead that otherwise would be necessary If resource conservation is not a 
concern, such components are alternatively provided on a permanent basis to provide 
a fixed, dedicated pipeline 26 for each protocol 

Once the network driver component 3 0 and net work interpreter component 
32 have been created, network executive component 14 delegates all responsibility 
25 for serving the particular network client 1 2 to the driver/interpreter pair The 

network executive component 14 communicatively binds network client 1 2, network 
driver component 30, and network interpreter component 32 to one of output 
interpreter components 22, using handle information previously provided to the 
network executive component 14 by the interface executive component 20 

Each of network driver components 30 is configured to receive the image 
information from a network client 12 according to one of a plurality of different 
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network interface protocols. Each network interface protocol is specifically 
associated with one of network clients 12, and reflects the modality-specific 
requirements for communication with the particular network client Each of the 
network interpreter components 30 is configured to generate first imaging requests 
according to one of the network interface protocols based on the content of the 
received image information. The first imaging requests are generated by network 
interpreter component 32, and correspond to imaging requests generated by network 
client 12. The first imaging requests are communicated to output interface 
component 16. 

Each of the network interface protocols includes both a network driver 
protocol applicable to network driver components 30 and a network interpreter 
protocol applicable to network interpreter components 32 The appropriate network 
driver protocol is determined by the communication requirements of a particular 
network client 12, whereas the appropriate network interpreter protocol is 
determined by the image information format of the particular input imaging device 
associated with the network client The image information format refers to the types 
of imaging requests generated according to the protocol of a particular input imaging 
device. The network driver protocol specifies the manner in which a network driver 
component 30 should carry out the transfer of image information from an input 
imaging device associated with a network client 12 The network interpreter 
protocol specifies the manner in which network interpreter component 32 should 
interpret the image information to generate the first imaging requests The network 
driver and network interpreter protocols can vary significantly according to 
differences in the type of network client 12, as well as the manufacturer of the input 
imaging device 18. 

The network interpreter component 32 also shares a common set of tasks 
with other network interpreter components, without regard to a specific network 
interpreter protocol. Primarily, after obtaining image information from a network 
driver component 30, a network interpreter component 32 analyzes requests 
contained in the image information and translates them to generate first imaging 
requests corresponding to operations provided by output imaging device 1 8 The 
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first imaging requests include requests for a vanety of common imaging services 
provided by output imaging device 18 

The manner in which network interpreter component 32 interprets the 
requests generated by network client 12 may vary according to the specific network 
interpreter protocol. The network interpreter component 32 understands the prec.se 
format, instructions, and timing constraints inherent in the image information 
generated by a particular network client 12. Nevertheless, all network interpreter 
components 22 still provide a common, basic function of generating first imaging 
requests. The network interpreter component 32 sends the first imaging requests 
along pipeline 26. Once the first imaging requests have been processed by 
downstream components in bi-directional pipeline 26, and a response has been 
received, network interpreter component 32 forms an appropriate response for 
network client 12. The network interpreter component 32 sends the response along 
p.peline 26 to network client 12, via network driver component 30, which handles 
communication recrements necessary to transmit the response to the input imaging 
device. 

The network driver component 30 and network interpreter component 32 
have been described in recognition that a network interface component 33 could 
alternatively be implemented as a single, integral software module In the 
embodiment described, however, a network interface component 33 ,s realized by a 
discrete network dnver component 30 and a discrete network interpreter component 
32. A discrete implementation of the sub-components divides the functionality of 
each network interface component 33 into smaller packages for better modularity. 
Thus, as an example, with added modularity, changes in hardware specifications for 
network interface 28 require only reconfiguration of network driver component 30, 
instead of the entire network interface component 33. 

Furthermore, notwithstanding functions specific to a particular protocol 
components 30 and 32 of like type (i.e., all network driver components) are 
configured to perform several common tasks For example, network dnver 
components 30 share a set of common tasks necessary to communicate with a 
network client 12 operating according to particular network protocol A network 
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driver component 30 is configured to handle any hardware specifics such as 
interrupts, buffers and handshaking necessary to transfer imaging information to and 
from a particular network client 12. The network driver component 30 is further 
configured to handle any other specific needs of a network client 12, such as 
packetizing or initialization. The network driver component 30 performs all 
necessary communications tasks, isolating the remainder of pipeline 26 from any 
knowledge of the specific requirements for communication with the network client 
12. Thus, the responsibility of network driver component 30 is two-fold. First, 
network driver component 30 receives image information offthe network from 
network client 12, and prepares the image information for the next stage of pipeline 
26, i.e., network interpreter component 32 Second, network driver component 30 
transmits any responses emerging from bi-directional pipeline 26 onto the network 
for communication to network client 12. 

Components of the Invention: Output Interface Components 

15 Still referring to FIG. 1, each of output interface components 16 is configured 

to generate second imaging requests according to one of a plurality of different 
output protocols, via one of output interpreter components 22, based on the content 
of the first imaging request. The second imaging requests represent the content of 
the first imaging requests, as translated by output interpreter component 22 for 

20 communication to output imaging device 1 8. Each output interface protocol is 
specifically associated with the type of output imaging device 18 and, like the 
network interface protocol, reflects the requirements for communication with the 
particular output imaging device. In addition, each of the output interface 
components 16 is configured to communicate the second imaging requests to output 

25 imaging device 18, via output driver component 24, according to one of the output 
interface protocols. 

Each of the output interface protocols includes an output interpreter protocol 
applicable to output interpreter components 22 and an output driver protocol 
applicable to output driver components 24. The output driver protocol is determined 
30 by the communication requirements of output imaging device 1 8, whereas the 
appropriate output interpreter protocol is determined by the image information 
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format of the output imaging device The output interpreter protocol specifies the 
manner in which output interpreter component 22 should interpret first imaging 
requests to generate second imaging requests in a form understood by output imaging 
device 1 8. The output driver protocol specifies the manner in which an output driver 
5 component 24 should carry out the transfer of second imaging requests to output 
imaging device 18. Like the network interface protocols, the output interface 
protocols are subject to variation. For example, both the output driver and output 
interpreter protocol can vary according to the type of functional capabilities provided 
by output imaging device 18, e.g., 831, 952, or SuperSet in the case of a laser imager 
10 manufactured by Imation. 

An output interpreter component 22 is configured to receive, via pipeline 26, 
first imaging requests generated by a network interpreter component 32, and to 
interpret the first imaging requests to generate second imaging requests, which 
conform to the particular protocol required by output imaging device 18 The second 
1 5 imaging requests correspond to the first imaging requests in substance, but are 

configured according to the output protocol understood by output imaging device 
18. Thus, the second imaging requests serve as requests for the same imaging 
services specified by first imaging requests. The manner in which an output 
interpreter component 22 interprets the instructions may vary according to the 
20 specific output interpreter protocol dictated by output imaging device 1 8, but all 

output interpreter components 22 share a common task of generating second imaging 
requests in a protocol understood by the output imaging device The output 
interpreter component 22 sends the second imaging requests along pipeline 26 
When output imaging device 18 processes the second imaging requests and 
25 formulates a response received via pipeline 26, output interpreter component 22 

removes any output protocol-specific information and forms an appropriate response 
for network interpreter component 32. 

Referring now to the output driver component 24, like network driver 
components 30, all output driver components 24 perform a common set of 
communication tasks. Specifically, an output driver component 24 is configured to 
handle any hardware specifics such as interrupts, buffers, and handshaking necessary 



30 



20 



10 



15 



WO 98/15092 PCT/US97/I7407 

to transfer imaging information to and from a particular output imaging device 18 
The output driver component 24 isolates the remainder of pipeline 26 from any 
knowledge that communication with output imaging device 1 8 is carried out via a 
serial interface, a parallel interface, or a dual-port RAM, etc. The output driver 
component 24 transmits second imaging requests generated by an output interpreter 
component 22 to output imaging device 18, maintaining any communication 
requirements. Further, output driver component 24 receives responses from output 
imaging device 18, and prepares the response for transmission to output interpreter 
component 22 via bi-directional pipeline 26 

The output interpreter component 22 and the output driver component 24 
have been described in recognition that an output interface component 16 could 
alternatively be implemented as a single, integral software module. In the 
embodiment described, however, an output interface component 16 is realized by a 
discrete output interpreter component 22 and a discrete output driver component 24 
A discrete implementation of the sub-components divides the functionality of each 
interface component 16 into smaller packages for better modularity. Thus, as an 
example, with added modularity, changes in hardware specifications for interface 
component 16 require only reconfiguration of output driver component 24, instead of 
the entire interface component 16. 
20 Object-Oriented Nature of the Components 

To facilitate the interchangeability of the components, as has been described, 
the software interfaces between components 30, 32, 22 and 24 must be pre-defined 
to make each type of component generic. At the same time, however, an individual 
component 30, 32, 22 and 24 must be configured to implement functions specific to a 
particular protocol Object-oriented techniques, particularly that of inheritance, are 
used by the present invention to develop a generic base-class protocol for each type 
of component (e.g., network driver component 30) 

Inheritance is a particular object-oriented technique that serves as a 
mechanism for creating new classes from an existing class. A new class looks similar 
to an existing class except that it differs from the existing class in a small way; 
inheritance is employed to define the new class in terms of the existing class The 
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existing class that serves as a source for inheritance is referred to as a base class, and 
the new class derived from the base class is referred to as the derived class. An 
existing class can serve as a base class to more than one derived class. The base class 
is a definition of a more generic class of software objects, while the classes derived 
> from the base class define more specific or specialized cases of the objects Thus, the 
generic base-class protocol specifies the functions provided by a component and the 
procedures for accessing such functions. Each specific protocol component 
"inherits" from the corresponding base class protocol, and implements the interface to 
conform to the environment. 

Class inheritance allows the members of one class to be used as if they were 
members of a second class. No additional programming is required to implement the 
subclass, except for those operations that either extend or replace the members 
inherited from the other classes As that object-oriented system is developed, 
subclasses are constructed out of existing classes until the appropriate functionality is 
developed. The construction of subclasses results in the formation of a class 
hierarchy. The class hierarchy is rooted in the base class, which contains a minimal set 
of behavior common to all subclasses. 

In accordance with the present invention, each component 30, 32, 22 and 24 
is configured according to a specific protocol, but also serves as a sub-class of the 
base class protocol Because each component 30, 32, 22 and 24 inherits from the 
base-class protocol and implements a minimal set of functions such that they meet 
base-class requirements, it can be directly interchanged with any other component of 
like type that inherits from the same base-class protocol The interchangeability 
resulting from the object-oriented techniques produces a "direct-connect" software 
architecture in which each component can be effectively plugged into pipel.ne 26" 
without the need for additional interface development 

FIGS. 5 and 6 provide an example of an object-oriented protocol hierarchy 
that facilitates interchangeability of components 30, 32, 22 and 24 The protocol 
hierarchy illustrates the implementation of components 30, 32, 22 and 24 for specific 
protocols that as a derived class each "inherit" from a generic base-class protocol. As 
shown in FIG. 4, a network executive base-class protocol 34 may encompass a 
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plurality of "inheriting" network executive protocols 40, 42, 44 for different network 
clients 12 such as, for example, DICOM, Picker, and LP that allow an appropriately- 
instantiated network executive component 14 to detect the presence of a particular 
network client. Similarly, a network driver base protocol 36 may encompass a 
5 plurality of "inheriting" network driver protocols 46, 48, 50 for different network 
interface requirements associated with a network client 12 such as, for example, 
DICOM, Picker, or LP. A base-class network interpreter protocol 38 may 
encompass a plurality of inheriting network interpreter protocols 52, 54, 56 for 
different types of input imaging devices or manufacturers associated with network 
10 clients 12 such as, for example, DICOM, Picker, and LP. 

As shown in FIG. 5, a base-class output interpreter protocol 35 may 
encompass a plurality of inheriting output interpreter protocols for different types of 
output imaging devices 18, such as an lmation SuperSet output interpreter protocol 
41, an lmation 831 output interpreter protocol 43, or an lmation 952 output 
1 5 interpreter protocol 45. Finally, a base-class output driver protocol 37 may 

encompass a plurality of inheriting output driver protocols for different hardware 
interface requirements associated with output imaging device 18, such as a dual-port 
RAM output driver protocol 47, a serial output dnver protocol 49, or a parallel 
output driver protocol 51. Each of the inheriting protocols described above includes 
10 protocol-specific functions provided by a component 30, 32, 22 and 24, but 

implements such functions via a generic interface that inherits from the corresponding 
base-class protocol 34, 35, 36, 37, 38. For each base-class protocol 34, 35, 36, 37, 
38, described above, a variety of additional inheriting protocols can be implemented, 
according to the requirements of the medical imaging system environment. 
!5 Therefore, the nature of components 30, 32, 22 and 24 enables them to be 

selectively "swapped" in or out of a pipeline 26 in a modular fashion by interface 
executive component 20. Each of the components 39, 32, 22, 24 is made 
interchangeable with another component of like type, but different protocol, by a 
series of software interfaces. This base-class interface is in one embodiment built into 
0 each component such that any component 30, 32, 22 and 24 in a pipeline 26 can be 
replaced without affecting the configuration of the other components in the pipeline 
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Thus, individual components 30, 32, 22 and 24 also can be reused, significantly 
reducing costs previously associated with redesign efforts 

For example, if pipeline 26 were to be configured for communication between 
Siemens network clients 12 and an output imaging device 18 implementing Imation 
5 SuperSet functionality, interface executive component 20 would first instantiate a 
network executive component 14 configured to monitor the presence of Siemens 
network clients. Upon detection of a Siemens network client 12, network executive 
component 14 would spawn a network driver component 30 and network interpreter 
component 32 configured to operate according to the Siemens network protocol 

10 Specifically, network driver component 30 would be configured to operate according 
to a network driver protocol appropriate for receiving imaging information from the 
Siemens network client 12. The network interpreter component 32 would operate 
according to a network interpreter protocol appropriate for generation of first 
imaging requests based on the format of the image information received from the 

15 Siemens network client The network executive component 14 then would 

communicatively bind the network driver component 30 and network interpreter 
component 32 with an output interpreter component 22 having an output interpreter 
protocol appropriate for generation of second imaging requests understood by the 
Imation SuperSet output imaging device, the network interpreter component 32 

20 already being bound to an output driver component 24 having an output driver 

protocol appropriate for communication of the second imaging requests via a serial 
hardware interface associated with the Imation SuperSet output imaging device 
Alternatively, if a pipeline 26 were to be configured for communication 
between a Toshiba network client 12 and an Imation SuperSet output imaging device 

25 1 8, it would only be necessary to "swap" the network driver component 30 and 
network interpreter component 32 with components configured according to 
network driver and network interpreter protocols, respectively, appropriate for the 
Toshiba modality. Specifically, a network executive component 14 instantiated to 
listen for Toshiba network clients 12 would spawn a network driver component 30 

30 and network interpreter component 32 configured to operate according to the 

Toshiba protocol. The output interface component 16 used for Siemens network 



24 



15 



20 



25 



30 



WO 98/15092 

PCT/US97/17407 

clients 12 could be replicated and used in a separate communication pipeline 26 for 
Toshiba network clients. The output interface component 16 would include an 
Imation SuperSet-coiifigured output interpreter component 22 and an Imation 
Superset serial-configured output driver component 24, and therefore would already 
> be configured according to the requirements of output imaging device 1 8, 
independently of the protocol of network client 12 Thus, network executive 
component 14 would communicatively bind in a separate pipeline 26 the network 
driver and network interpreter components 30 and 32 with the standard output 
interpreter and output driver components 22 and 24 configured for the Imation 
Superset output imaging device, and useful in any pipeline having . SuperSet output 
device, and which are already bound to one another 

As another alternative, if the pipeline 26 described above were to be modified 
for communication between a Toshiba network client 12 and an Imation 952 output 
imaging device 18, only modification of output interface component 1 6 would be 
necessary. Specifically, network executive component 14 would communicatively 
bind the network driver component 30 and network interpreter component 32 with 
an output mterpreter component 22 having an output interpreter protocol appropriate 
for generation of second imaging requests understood by the Imation 952 output 
imaging device, which is already bound to output driver component 24 having an 
output driver protocol appropriate for communication of the second imaging requests 
via a serial hardware interface associated with the Imation 952 output imaging 
device. Thus, the network driver and interpreter components 30, 32 spawned by 
network executive component 14 would be unaffected by a change in the output 
imaging device 28 associated with communication pipeline 26. 

Finally, if the pipeline 26 described above were to be modified for 
communication between a Toshiba network client 1 2 and an Imation 952 output 
imaging device 18, having a dual-port RAM interface, only modification of output 
interface component 16 would be necessary. Specifically, network executive 
component 14 would communicatively bind the network dnver component 30 and 
network interpreter component 32 to an output interpreter component 22 having an 
output interpreter protocol appropriate for generation of second imaging requests 
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understood by the Imation 952 output imaging device, which is already bound to an 
output driver component 24 having an output driver protocol appropriate for 
communication of the second imaging requests via a dual-port RAM hardware 
interface associated with the Imation 952 output imaging device. Thus, network 
5 interface component 14, including Toshiba-configured network driver and interpreter 
components 30, 32 would be unaffected by the modification 

The present invention's employment of inheritance conceptions of object- 
oriented programming provide for the advantage of reusability of network driver and 
interpreter components, as well as simplification in the creation of new network 

10 driver and interpreter components. Inheritance makes it possible to define new 

components by comparison with already developed components, which is known as 
differential programming Common functionality within these components is reused, 
and therefore does not need to be redeveloped Furthermore, any bug fixes and 
enhancements made to the base class are automatically propagated to the derived 

1 5 classes In these ways, the present invention allows for the incorporation of new 

protocols into the software system in typically a shorter period of time, and utilizing a 
smaller number of resources, than is accomplished by the prior art 
Client-Server Hierarchy of the Components 

As shown in FIG. 6, interface executive component 20 in one embodiment 

20 defines pipeline 26 according to a client-server architecture In FIG. 6, an arrow 
pointing from a component A to a component B indicates that component A is a 
client component of server component B The bi-directional arrows between 
network driver component 30 and network client 12 and between output driver 
component 24 and output imaging device 18 do not represent a client-server 

25 relationship, but rather the hardware/software interfaces of medical imaging system 
10. As indicated by the arrows in FIG. 6, interface executive component 20 in one 
embodiment defines the client-server relationship of the software system such that 
(1) interface executive component 20 is a client component of network executive 
component 14, output interpreter component 22 and output driver component 24, (2) 

30 network executive component 14 is a client component of network driver component 
30 and network interpreter component 32, (3) network driver component 30 is a 
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client component of network interpreter component 32; (4) network interpreter 
component 32 is a client component of output interpreter component 22; and (5) 
output interpreter component 22 is a client component of output driver component 
24. 

5 The client-server paradigm provides for seamless integration among the 

components of the present invention. The client component requests a service to be 
performed; the server is the resource that handles the client's request More 
specifically, the client sends a message to a server to request that the server perform a 
task, such that the server responds to the client's request. Employing client-server 
10 relationships in the present invention allows for the advantage of increased 

maintainability above and beyond that provided by object-oriented programming 
precepts. Client-server computing recognizes that the separate components provided 
for by an object-oriented architecture need not all be executed from the same memory 
space. Thus, client-server computing promotes scalability: any of the components of 
1 5 the present invention may be replaced when the need to either grow or reduce 
processing for that component dictates, without significantly impacting the other 
components As has been described, the components of the present invention reside 
within the same memory, be it on a card within the imaging device, or within the 
RAM of a computer to which the device is coupled However, should the number of 
20 imaging devices with which the clients can communicate become relatively large, for 
example, the output interface components for each device could reside on a card 
within the device, while the remainder of the components could reside on a computer 
attached to the network. As a result of subscription to a client-server model, the 
present invention allows for relocation of individual components without great logical 
25 effect to the other components 

In the described client-server relationship of the present invention, output 
driver component 24 is purely a server component for output interpreter component 
22, respectively. The output driver component 24 is responsible for low-level 
hardware requirements and is under control of the higher-level output interpreter 
30 component 22, respectively. The network interpreter component 32 is a client 

component of output interpreter component 22, which provides a set of functions by 
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which the network interpreter component controls output imaging device 18. The 
output interpreter component 22 never initiates communication with network 
interpreter component 32, but rather provides services at the request of the network 
interpreter component. The network driver component 30 is a client component of 
5 network interpreter component 32, which communicates with the driver component 
30 to receive and interpret the image information from a client to generate the first 
imaging requests. The network driver component 30 itself directly communicates 
with the clients, however, according to a particular protocol. Finally, every 
component 30, 32, 22 and 24 is a server component for interface executive 
10 component 20. Thus, interface executive component 20 ultimately controls the entire 
software system. 

Communication Among the Components 

Communication among the components of the present invention is carried out 
via the issuance of remote procedure calls (RPC's) A remote procedure call is a 

15 common communication mechanism often used in complex distributed software 
systems. A client component executes a particular function by issuing a remote 
procedure call to a corresponding server component The remote procedure call 
handles all of the mechanisms necessary for inter-component communication Each 
component is configured to provide services to a client component, but is unaware of 

20 which or how many components are actually using it as a server component. The 
server components simply perform the requests of the client components without 
exhibiting protocol-specific dependencies 

Employment of remote procedure calls allows the present invention to have 
advantages resultant of a concept called encapsulation. Encapsulation of a 

25 component means that other components only see the services or tasks that the 
component offers, with no visibility as to how these services and tasks are 
implemented. Thus, how a component implements its actions, and how its internal 
data is arranged, is "encapsulated" inside a procedural shell that mediates all access to 
the object via remote procedure calls Only the component itself has visibility into its 

30 procedures and its data The components of the present invention are, therefore, 
encapsulated units of functionality Put another way, encapsulation enables 
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information hiding and data abstraction The actual method followed by a particular 
component is an implementation detail that is independent of how the data is used 
Rather, the operations that can be performed on the encapsulated data are specified 
as part of the interface to the component, the remote procedure calls Thus, the 
implementation details of the operations that manipulate the stored data can be 
changed without affecting the remote procedure calls. Along with the inheritance the 
concept of encapsulation allows for the advantage of interchangeability of 
components within the present invention. 

In one embodiment of the present invention, a remote procedure call is used 
to execute a function in the following manner First, when a software process being 
performed by a client component needs to execute a particular function, the process 
amply calls the function by its identifier. A layer of software residing within the 
client component, commonly referred to as a "client stub," traps the function call If 
the client stub determines that the software code necessary to perform the called 
function actually exists within another server component, the Cent stub creates a 
message enclosing any data passed with the function call, as well as any necessary 
packetizing and addressing. The client stub, in one embodiment, then sends the 
message to the server component via the real time operating system existing in the 
software system. The server module contains a layer of software code, known as the 
"server stub," that receives the message. The server stub strips apart the message 
and actually calls the correct local function with any data pulled from the message 
The local function executes as if i, were originally called locally, returning any 
information requested The server stub creates a response based on the returned 
"formation, and sends the response to the client component v ia the operating system 
Upon receipt of the response, the client stub pulls out the returned information and 
passes the information to the local software process that originally called the 
function The local software process then continues unaware that any ,„,er-modu.e 
communication occurred. 

Component Definitions of One Embodiment of the Present Invention 

The following sub-sections provide details concerning the manner ,n which 
each base-class protocol can be implemented in an embodiment of medical imaging 
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system 10 of FIG. 1, in accordance with the present invention The sub-sections 
provide definitions and requirements of services provided by each of components 30, 
32, 22 and 24, 14 represented for purposes of illustration in the C++ object-oriented 
programming language, with comments included where appropriate Where C++ 
code is used below to illustrate the functionality of a particular component, the label 
"host" may be used to refer to network client 12 and the label "laser imager" or "LI" 
may be used to refer to output imaging device 1 8. 

The Network Executive Base-Class Protocol 

The network executive base-class protocol, in this embodiment, includes one 
remote procedure call that network executive component 14 is required to provide 
for its client component, interface executive component 20. The remote procedure 
call is described below in terms of the types of parameters handled and the functions 
performed. 

1 set_debugjevel Parameters: Type 

15 debug level DEBUG LEVEL 

Returns: Type: 
void " n/a 

The actual base class protocol for network executive component 14 can be 
defined in C++ code as follows: 

20 class NETWORK EXECUTIVE { 
protected: 

LI INTERFACE *li_handle; // pointer to laser imager interface 

INT32 return_cod e> // rc for OS operations 

DEBUGLEVELS debugjevei; . //Debug level for module 
25 DvlAGER_CONFIG *im_cfg; // imager/dicom configuration object 

public: 

NETWORK_EXECUTIVE(LI_INTERFACE IMAGER CONFIG *) 
virtual -NETWORKJEXECUTIVE(void); 
^ ^ virtual void set JebugJevel(DEBUG_LEVELS level), //set to new debug level 

The base class protocol for a DICOM protocol-configured network executive 
component can be defined in C++ code as follows: 

class DICOM_EXEC : public TaskVStack, public NETWORK EXECUTIVE! 
friend class EVENT MGR; 
35 private: 

void execute(void); 

30 
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Bool init_network(); //initialize DIMSE interface to net 

int connect(); //monitor network and wait for a SCU 

Bool checkHeapSpace(); //Check if enough heap for new SCU 

Bool checkHeapSpaceVerO, //Check if enough heap for new verify-only SCU 
5 public: J J 

int numConnections; 

int numConnectionsVer; 

Bool verification only, 

int port; 

10 int network_socket; // socket for executive to listen to network 

int assoc sockfd; // socket for new association 
DIMSE_nethandle netHandle; 

DICOM_EXEC(LI_INTERFACE *, IMAGER CONFIG *V 
~DICOM_EXEC(void); ~ 
15 void async_handler(char, ID), 

//Asyncronous commands from Dicom Driver 

void set_debugJevd(DEBUG_LEVELS level); //set to new debug level 

In this example, the DICOM executive base class contains two remote procedure 
calls: set_debug_level() and async_handler() The async_handler() RPC allows a 
DICOM_Driver to inform the DICOM_executive that it has completed a task and 
should be shut down 

The Network Driver Base-Class Protocol 

The network driver base-class protocol, in this embodiment, may include two 
remote procedure calls: set_debugjevel() and n L event_handler() The remote 
procedure calls are described below in terms of the types of parameters handled and 
the functions performed 

1 set_debug_levei Parameters Type: 

debug leveL DEBUG LEVEL 

Returns: Type: 

void n/a 

2 ni event handler Parameters: Type: 

Network Interpreter event NIEVENT 
Returns: Type: 
void ^ 
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The nievent-handler RPC receives asynchronous events from output imaging device 
18 that are propagated via network interpreter component 32, output interpreter 
component 22 and output driver component 24 

As noted above, the network driver component 30 provides a mechanism for 
5 handling asynchronous events received from output imaging device 18 The events 
serve to inform network driver component 30 of a status change at output imaging 
device 1 8. Various events indicating the status of output imaging device 1 8 may 
include (1) NI_printer_update, which indicates that the output imaging device has 
changed it status, and (2) NI_printJob_update, which indicates an imaging job has 
10 changed its status The function of the above status events is to avoid the need for 
the network client 12 to continuously poll output imaging device 18 

The actual base class protocol for the network driver component 30 can be 
defined in C++ as follows: 

class NETWORK JDRIVER{ 
15 protected: 

INT32 returncode; // RC for OS operations 
ID assocsocket; // socket descriptor for association 
LMAGERCONFIG *imager_cortfig; // Configuration information 
NETWORK_DRIVER(ID port, DEBUG_LEVELS,IMAGER_CONFIG *) 
20 virtual -NETWORK_DRl VER( voi d) ; 

public: 

DEBUGLEVELS debugjevel; //Debug level for module 
virtual void set_debugJevel(DEBUG_LEVELS level); //set to new debug level 
virtual void n i even t hand 1 er (N I E VENT ,N 1 async data)-0 
25 }; " ~ ~ 

The base class protocol for a DICOM protocol-configured network driver 
component may make use of a DD_NET_MONlTQR object, which can be defined in 
C++ code as follows: 

class DDNETMONITOR : public TaskVStack{ 
30 private: 

DICOMJDRIVER ^master; //pointer to controlling object 

void execute(void); //main execution thread 
public: 

DD_NET_M0N1T0R(DIC0M DRIVER *); 
35 -DDNETMONITOR(void); 

}; 

typedef enum { 

DDPrinterStatusChange, 
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DDJobStatusChange 
} DDevent; 

The DD NET MONITOR is an object internal to a DICOMDRJVER object that 
5 implements the DICOM driver component. The DDNETMONITOR object 
continuously monitors the network for incoming messages and informs the 
DICOM_DRIVER object upon their arrival The DICOM DRJVER object then 
reads and processes the messages, passing any information to the 
DICOMINTERPRETER object (network interpreter component 32) via RPC-based 
10 functions defined by the network interpreter component 

The base class protocol for a DICOM protocol-configured network driver 
component can be defined in C++ code as follows: 

class DICOM J5RIVER : public TaskVStack, public NETWORKDRIVER { 
friend class DD NET MONITOR; 
15 private: 

DD NET_MONITOR networkmonitor; //get messages from network 
//Association handling Methods and Parameters 
void associationServer(); //handle association 

void monitorNetwork(), //continually accept and valid DICOM messages int 
20 processMessage(); //handle the received DICOM message 
//FilmSession Methods and Parameters 

void hand!eFilmSession(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg), 
void fsNCreate(DIMSE_CmdSet cmdSet, DIMSEMsgHandle msg), 
void fsNSet(DIMSE_CmdSet cmdSet, DIMSEMsgHandle msg), 
25 void fsNAction(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg), 

void fsNDelete(DlMSE_CmdSet cmdSet, DIMSEMsgHandle msg), 
//FilmBox methods and parameters 

void handleFiImBox(DlMSE_CmdSet cmdSet, DIMSEMsgHandle msg), 
void fbNCreate(DIMSE_CmdSet cmdSet, DIMSEMsgHandle msg); 
30 void fbNSet(DIMSE_CmdSet cmdSet, DIMSEMsgHandle msg); 

void fbNAction(DlMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg); 
void fbNDelete(DIMSE_CmdSet cmdSet, DIMSEJVlsgHandle msg), 
//ImageBox methods and parameters 

void handlelmageBox(DIMSE_CmdSet cmdSet, DIMSEMsgHandle msg), 
35 void ibNSet(DIMSE_CmdSet cmdSet, DIMSE MsgHandle msg), 

//Annotation Box methods and parameters 

void handleAnnoBox(DIMSE_CmdSet cmdSet, DIMSE MsgHandle msg); 
void abNSet(DIMSE_CmdSet cmdSet, DIMSE MsgHandle msg); 
//Printer methods and parameters 
40 void hand!ePrinter(DlMSE_CmdSet cmdSet); 

void prNGet(DIMSE_CmdSet cmdSet); 
//PrintJob methods and parameters 
void handlePrintJob(DIMSE_CmdSet cmdSet); 
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void pjNGet(DIMSE_CrndSet cmdSet); 
//Misc functions 

pubUc° id 3SynC - evCnt - Server 0; ^rver function called «o process async events 

Sl^p "f W ^ R(DIC ° M - EXEC ^ DIC0M INTERPRETER ♦ 
DIMSE_AssocHandle,DIMSE_SOPlnfo*, ~ ' 



}; 



DEBUGJLEVELS, IMAGER CONFIG • V 
-DICOM DRIVER(void); ~ 

voidni_event_handler(NI_EVENT,Nl_async_data); 



In th,s example, the DICOM_DRIVER includes a large number of ft.nct.ons that 
operate on incoming DICOM messages. Most of the fbnctions can be rather 
DICOM-specific and will be apparent to those skilled in the art in view of the 
DICOM standard. Each of these functions ,s internal and ,s closely tied to related 
DICOM DIMSE commands. In addition, the DICOM_DRIVER contains the RPC 
call that was specified in the networkjriver base class: ni_event handlerQ The 
DICOM functions ultimately call network interpreter-specific functions that use the 
RPC mechanism. 

The Network Interpreter Base-Class Protocol 

The network interpreter base-class protocol, in this embodiment, includes 
remote procedure calls that network interpreter component 32 is required to provide 
for its client component, network executive component 14 

The actual base class protocol for network mterpreter component 32 can be 
defined by the following C++ code ,n which the network interpreter is referred to as 
the "NETWORK INTERFACE": 

//Define asyncronous events for network interface 
typedef enum { 

NJ_printer_update, // Announce that the Li's status has changed 

} NI_E^NT J ^ iWUCC th3t 3 Pnm J ° b ' S Status has <*™ged 
typedef union ( 

int id, // ID of component that has changed its status 
} NI async data; 

typedef NET WORK_DRI VER *ND PTR, // pointer to ND client 
typedef void (NETWORK JDRJVER-ND METHOD PTR) 
// pointer to client method 
(NI_EVENT, Nl_async_data) 
class NETWORK1NTERFACE { 

34 



WO 98/15092 



PCT/US97/17407 



10 



protected: 

INT32 return code; // RC for OS operations 
ID port Jd, // initial network port 
Semaphore rpc reply; // RPC response complete 
Semaphore rpcjree, // RPC mailbox free 
Semaphore event_reply; // async event received 
Semaphore event_free; // async event mailbox free 
Mailbox event_mbox, // event mailbox 
Mailbox rpc_mbox, // RPC mailbox 
ND_PTR driver, // driver module calling us 

ND_METHOD_PTR driver_async_handler; // pointer to async handler 
IMAGERCONFIG 'iconfig; // pointer to imager configuration object 
NETWORK_INTERFACE(ID, LIINTERFACE * DEBUG LEVELS 

IMAGER CONFIG *); ' " 

virtual -NETWORK lNTERFACE(void); 
LIINTERFACE *li_handle, // Handle to LI interface 
DEBUG LEVELS debug Jevel; // Debug level for module 
Param Blk parameters; // Pointer to parameters 
LI_async_data ILasyncdata; // Data from LI events 

20 public: 

virtual Bool Ii_event_handler(LI_INTERFACE EVENT t LI async data) 
virtual void se^asyncJuncCNDJ'TR, NDMETHODPTR) " 
virtual void set_debugJevel(DEBUG ^LEVELS level);"//set new debug level 
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A base class protocol for a DICOM protocol-configured network interpreter 

component can be represented by the following C++ code: 

// DICOM Interface Message type for RPCs 
typedef struct { 

SI^-n° mmand comn,and i //DICOM command/event to execute 
DICOM^Response 'response, // Pointer to response object 
DICOM Data data, // message data 
} DICOM Message, 

class D1COMJNTERFACE : public Task VStack public 
NETWORK INTERFACE, - 

public PrintServerlnf, public SessionHandler ( 
pnvate: 1 

DICOM^Message "message; // Pointer to RPC client message 
DICOMJtesponse 'response, //Pointer to response object 
DICOM Data *data; // message data 
INT32 return_code; // rpc return code 
PrinterStatus currentPrStatus, 
void execute(void); 

void send_rpc(DICOM_Message •); // Send msg to se^er thread 
vo.d ack_rpc(void); // Acknowledge RPC completion 

45 public: 

DICOM_INTERFACE(ID, LI INTERFACE *, DEBUG LEVELS, 
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IMAGER CONFIG *); 
-DICOM INTERFACE(void), 

Bool li_event_hand!er(LI_INTERPACE_EVENT > LI async data); 
// Async event handler 

5 }; 

class PrintServerlnf ; public BasePrintServer { 
public: 

// Constructor - initialize the data members and establish 
10 //a connection with the PrintServer process. 

PrintServerlnflpiCOM^INTERFACE*, I M AGERC ONFI G * ) , 
// Destructor - cleanup session and memory dynamically allocated 
~PrintServerInf(); 

// This method opens a film session at the PrintServer and 

15 // returns a pointer to a FilmSessionlnf object. 

FiimSessionlnf* openSession() { return openSession(String()), } 
FilmSessionlnf* openSession(const String& origld), 
// This method closes the session at the PrintServer, resulting 
// in the deletion of all images previously stored in the session 

20 // and all the open film boxes, 

void closeSessionO; 

// This method gets the status information of a job specified by its id 
bool getJobStatus(JobStatus& status, ID jobld); 
// The following methods allows a client to manipulate jobs on the 
25 // Print Server queue. 

// This method removes a job from the server's queue, 
bool cancel(ID jobld); 

// This method changes the priority of a job in server's queue, 
bool alterPriority(ID jobld, Priority p); 
30 11 This method returns an object containing printer status information 

bool getPrinterStatus(PrinterStatus& status); 
// This method notifies the server to shutdown, 
void shutdownQ, 

void setHostName(const String& name); 
35 void setHostName(char* name); 

protected: 

void connect(); 

bool getPrintQueue(JobIdArray& jobs, ID sessionld, const String& origld) 
DICOM INTERF ACE * master; 
40 IMAGERCONFIG *m_config; 

private: 

FilmSessionlnf* m_fs; 

}> 

class SessionHandler { 
45 friend class DICOM INTERFACE; 

public 

DICOMINTERFACE* master, 



36 



WO 98/15092 



PCT/US97/17407 



ID m_sessionId; 

ID m_fbld; 

ID m imgld, 

LIST mj>rintJobs; 
5 Bool m_contrastTest; 

int m_iniages_acquired; 

LSVRStatus macquirestatus; 

States mstate, 

String hostName; 
10 Bool m contrastTestMode; 

PARAMETERS mjiparams; 

IMAGE *image_list[MAX_IMAGES_PER_PAGE] > 

IMAGE image Jist_store[MAX_lMAGES_PER PAGE] ; 

IMAGE *raw_imageJist[MAX_IMAGES PER PAGE]- 
15 IMAGE rawjmageJist_store[MAX IMAGES_PER_PAGE], 

SessionHandler(DICOM_INTERFACE* m), 

virtual ~SessionHandler(); 

ID getSessionId(); 

ID getNextFilmBoxId() { return ++m_fbld, } 
20 ID getNextlmageId() { return ++m_imgld; } 

Boo! queryPrintfobs(ID jobld) { return m_printJobs.query(jobId); } 

void rnapJobStatus(JobStatus* js); 

Bool handleContrastTestEvent(char* nid), 

void printContrastTest(ID image), 
25 LSVR Status acquireA]HmageMemory(int rows, int cols), 

void sessionClientHandler(); 

void openSessionHandler(); 

void closeSessionHandler(); 

void newFilmBoxHandlerO; 
30 void printHandler(); 

void image AllocateHandler(); 

void imageDataHandler(); 

void deleteImageHandler(), 

void filmAttrHandler(); 
35 void image AttrHandler(); 

void associateImageHand!er(); 

void eraseImageHandIer(); 

void eraseAlIImagesO, 

void deleteFilmBoxHandler(), 
40 void getPrinterStatusHandler(); 

void getPrintQueueO; 

void geUobStatusHandler(); 

void cancelJobHandler(); 

void setPriorityHandlerO; 
45 void noImageHandler(), 

void errorHandlerO; 

void cleanUpImagesQ, 
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^ void updateParameters(BaseFilmSession *fs, BaseFilmBox *fb), 

The Output Interpreter Base-Class Protocol 
> The network interpreter component 32 interfaces with output interpreter 

component 22 via a set of imaging objects. The imaging objects serve as parameters 
for the remote procedure calls and contain all of the available information concerning 
the characteristics of output imaging device 1 8 and the imaging process The 
network interpreter component 32 can use any part of the information and disregard 
the rest. There are six imaging object definitions including (1) a box object, (2) a 
format object, (3) an image object, (4) a test image object, 5) a string object, and 6) a 
variety of general imaging parameter objects. 

A format object is used to describe an entire sheet of imaging media on which 
output imaging device 18 will form an image The format object holds information 
relating to film type, film size, border color, border density, etc. The charactersitics 
of the format object can be defined in C++ as follows: 

class FORMAT { 
public: 

FORMAT(FORMATID), //Constructor 

20 FORMAT(void); //Constructor 

vo.d inu(void); // Initialize parameters to defaults 

FORMATJD id, // Format to which this box belongs 

TABLE bkgnd_color_table, // Background/border color media table 
TABLE bkgnd_color_mixing_table;// Background/border color mixing table 

25 LEVEL bw_border_level, // B&W border level 

COLOR color_brd_level, // Border Color levels 

LEVEL bw_density_max, // B&W maximum density 

FILMTYPE filmjype; // Type of film to use 

FILM_SI2E film size; // Size of film to use 

30 }, 

A box is a rectangular area of the film sheet designated to hold an image. The 

box has many characteristics including location, size, contrast, color, etc The box 

definitions are associated with a particular format. That is, several boxes are used in 

conjunction with a particular format The following C++ code describes the box 

35 object and its characteristics: 

class BOX { 
public: 

BOXfBOXJD id,FORMAT_ID id); // Constructor 
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BOX(void), 
void init(void); 
BOXjDid; 
FORMAT ID format jd 
TABLE beta_xl; 
TABLE beta_yl ; 
TABLE beta_x2, : 
TABLE beta_y2, 
TABLE color_media_table; 
TABLE contrast table; 
TABLE color_contrast_tabJe; 
TABLE colormixingtable; 
FRAME frame, 
LOCATION xjocation, 
LOCATION yjocation; 
Switch mirroring; 
Switch rotation, 

0UTPUT_SI2E output_si Z e_x I 
OUTPUT_SIZE output_size_y 1 
OUTPUT_SIZE output_size_x2 : 
OUTPUT_SIZE output_size_y2;' 
OFFSET windowxofFset; 
OFFSET window_y_offset; 
LENGTH window xjength; 
LENGTH window_y_length; 

} y 
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// Constructor 

// Initialize parameters to defaults 

// Box id # 

// Format the box 

// Horizontal axis beta pass 1 

// vertical axis beta pass 1 

// Horizontal axis beta pass 2 

// Vertical axis beta pass 2 

// Color media table to use 

// B&W contrast table to use 

// Color contrast table to use 

// Color mixing table to use 

// Frame to use around border 

// Horizontal pixel location 

// Vertical pixel location 

// Turn mirroring on and off 

// Turn rotation on and off 

// X output size pass 1 

// Y output size pass 1 

// X output size pass 2 

// Y output size pass 2 

// Window X offset from corner 

// Window Y offset from comer 

// Horizontal length of window 

// Vertical length of window 



An image is represented by image data containing digital image values The 
image data is stored in an image memory associated with output imagmg device 1 8 
The image object is used to associate certain characteristics with the image As 
indicated by the above code, the charactenstics may include pixel length, pixel width 
Pixel depth, color format, etc When printing, an image is used to fill the boxes 
defined for the format that is to be used. The following C++ code describes the 
image object and its characteristics: 

class IMAGE { 
public: 

IMAGE(void), 

IMAGE(IMAGE JD id), 

void init(void); 

1MAGE ID id; 

COLOR FORMAT mode 

LENGTH xjength, 

LENGTH yjength;' 

DEPTH imagedepth; 



// constructor 
// constructor 

// Initialize parameters to defaults 
// Identification Number 
// color image format 
// horizontal image length in pixels 
// vertical image length in lines 
//depth of image 8-12 bits 
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DURATION timeout; // acquire timeout for this image 

Switch permanent; // image will be held for a while 

}; 

A test image object is used to symbolize images used for testing purposes 

5 The images are software generated and have different attributes than an image The 

following C++ code describes the test image object and its characteristics 

class TESTIMAGE { 
public: 

TEST_lMAGE(void); 
10 TEST_IMAGE(IMAGE_ID id); 

void init(void); 

IMAGE1D id; 

COLOR FORMAT mode; 

LENGTH x Jength; 
15 LENGTH y Jength, 

DEPTH image_depth; 

DURATION timeout; 

TESTJMAGE_TYPE imagejype, 

LEVEL red density; 
20 LEVEL greendensity, 

LEVEL bluedensity, 

}> 

A string object is used to hold ASCII text in the image memory The string 
25 object also allows the use of parameters such as length, intensity, type, etc. The 
following C++ code describes the string object and its characteristics: 

class STRING { 
public: 

STRJNG(void); 
30 STRING(IMAGE_ID id); 

void init(void); 

STRINGJD id; 

TEXT TYPE type; 

char *text; 
3 5 LEVEL bw foregndintensity ; 

LEVEL bwbackgndintensity; 

COLOR color foregndjntensity; 

COLOR colorbackgndintensity, 

LENGTH width; 
40 LENGTH lead, 

}; 



// constructor 
// constructor 

// Initialize parameters to defaults 

// Identification Number 

// color image format 

// horizontal image length in pixels 

// vertical image length in lines 

// depth of image 8-12 bits 

// acquire timeout for this image 

// type of test pattern 

// Constant density - red density; 

// Constant density - green density; 

// Constant density - blue density, 



// constructor 
// constructor 

// Initialize parameters to defaults 
// id of string 
// Type of the text 
// string 

// B&W forground intensity 
// B&W forground intensity 
// Color foreground intensities 
// Color background intensities 
// width of string 

// # of blank lines between ASCII lines 
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The general parameters object is used to hold all process configuration 
parameters. This object can be used to set the parameters in the laser imager, or to 
read the current settings of the parameters. Examples of some parameters are default 
beta tables, default color contrast, default destination, default film size and type, etc 
A few parameters are read-only, and thus cannot be set, such as the amount of 
memory available, the current software revision, the total prints queued, etc. The 
following C++ code describes the general parameter object and its characteristics 

class PARAMETERS { 
public: 

PARAMETERS(void); 

void setdefaults(void); 

DURATION acq_timeout; 

TABLEdefbetajcI; 

TABLE def_beta_yl; 

TABLE def_beta_x2; 

TABLE def_beta_y2; 

LEVEL def_bw_border; 

COLOR defcolorborder, 

COLORFORMAT def_cformat; 

TABLE def_bw_contrast; 

TABLE def_color_contrast; 

TABLE def_color_mix; 
LEVEL def_max_density; 
DEPTH def_depth, 
DESTINATION def_destination, 
LEVEL def bw dmax, 
IMAGE TYPE def_image_type, 
F1LMTYPE defjilmjype, 
FILM SIZE def_film_size; 
LENGTH defimagexsize, 
LENGTH def_image_ysize; 
Switch fixedformatting; 
FIXEDFORMAT fixed Jbrmat, 
/** Read only parameters *♦/ 
long int fixed_image_pattern; 
MEMORY memory; 
OP MODE op mode, 
RELEASE revision; 
SYSTEM system, 
int total queued; 
int totalcompleted; 
int total_failed; 

}; 



// Constructor 

// Initialize to defaults 

// Acquisition timeout 1 . 65535 seconds 

// Default horizontal axis beta pass I 

// Default vertical axis beta pass 1 

// Default horizontal axis beta pass 2 

// Default vertical axis beta pass 2 

// Default B&W Border level 

// Default color border level 

// Default acquisiton image format 

// Default contrast table while in B&W 

// Default contrast table while in color 

// Default mixing table while in color 

// Default maximum density value 

// Default bits per pixel 

// Default destination for print images 

// Default B&W maximum density value 

// Default acceptible image type 

// Default media type 

// Default media size 

// Default width of image in pixels 

// Default length of image in lines 

// Switch for fixed formatting 

// Fixed format number 

// Image acquisition pattern 
// Memory status structure 
// Operational mode 
// Current revision 

// Imaging system of the Laser Imager 
// Total prints queued in the system 
// Total prints completed in current jobs 
//Total prints failed in current jobs 
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One of the major responsibilities of output interpreter component 22 is to relay the 
status of the output imaging device 18 to the client component, network intrepreter 
component 32. The status relay process has two steps When output interpreter 
component 22 notes a status change in output imaging device 18, the event handler i 
5 the client component is called directly by the output interpreter component The 
event handler is passed a status event. The possible status events include (1) the 
FP_status_change, (2) the PR_status_change, (3) the LMS_j>tatus_change, (4) the 
JOB_status_diange, and (5) the XFR_status_change The output interpreter 
component 24 notifies the client, network interpreter component 22, of the above 

10 status changes, so that the network interpreter component does not need to 
continuously poll the laser imager. 

It is the responsibility of the client, network interpreter component 32, to 
either ignore the status change or request further information All status information 
is contained within five status objects. There is status object for the film processor, 

1 5 the printer, the image management system, jobs, and background jobs (transfers) 

Each status object has a status field which can be easily checked to see if warnings or 
errors exist If warnings or errors exist, further examination of the warnings 
structure or the error structure can be done. Again, the client can choose to use only 
the information it needs The following C++ code shows the definition for each of 

20 the status objects and the structures they contain 

/**Fi1m Processor Status object typedefs and class definition **/ 

// Constructor 
// clears status object 
//Id 

// Time till warm 
// Film Processor Type 
// Film Processor status 
// current warnings in Film Processor 
// current errors in Film Processor 

// Antares film processor 
// LT film processor. 
// No film processor connected. 
// Spectrum film processor. 

42 



class FilmProcessor { 
public: 

FilmProcessor(void), 
25 void clear(void); 

int id; 

int WarmingTime; 
FP_Type type; 
FP Status status; 
30 FP Warnings warnings, 
FPJErrors errors; 

}; 

typedef enum { 
AntaresFP, 
35 LT_SE154_FP 
NoJT, 
Spectrum_FP 
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} FPType, 
typedef struct { 
unsigned Busy ; 1 ; 
unsigned NoFP : 1; 
unsigned OpenLoop : 1, 
unsigned Ready : 1; 
unsigned Warming : 1 ; 
unsigned Warnings : 1, 
unsigned Errors : 1; 
} FP_Status; 
typedef struct { 
unsigned CheckChem : 1; 
unsigned Generic : 1, 
unsigned Hi Ovf : 1; 
unsigned LoChem : 1 ; 
} FP^Warnings, 
typedef struct { 
unsigned FPDown : 1 ; 
unsigned FuIIOvf ; 1; 
unsigned Generic ; 1 , 
unsigned MediaJam : 1, 
unsigned OutChem : 1; 
} FPErrors; 



// Processor is in clean-up or busy with media 

// No film processor docked 

//Not doing calibration 

// Ready to process film 

// Warming up 

// Warnings exist 

// Errors exist 



// Chemistry is getting bad 
// Miscellaneous 

// One or more overflow tanks is getting high 
// One or more chemistry tanks is getting low 

// Processor is not operational 

// One or more overflow tanks are fill] 

// Miscellaneous 

// Media jammed in the film processor 

// One or more film chemistry tanks are empty 



/"Image Managment System Status object typedefs and class definition**/ 

class ImageMgmntSystem { 

public: 

Image_Mgmnt_System(void); // Constructor 



}; 



void clear(void); 
IMS_status status, 
IMSerrors errors; 



// clears status object 

// Image Management System status 

// current errors in Image Management System 



// First status since it has been powered up. 
// Errors exist in the system 



typedef struct { 
unsigned PowerUp ; 1 ; 
unsigned Errors : 1; 

} IMSstatus, 

typedef struct { 
unsigned BadConfig 1; // IMS is configured improperly 
unsigned BadTOEprom : 1 ; // Table EPROMS have an incorrect checksum 
unsigned IMNVRamErr : iy/Non volatile ram error in an input module 
unsjgned IMSDown ; 1 ; // IMS is not operational 
unsigned OMN^ ; 1; //Non volatile ram error m 
unsigned OMm^amErr2 : 1; // Non volatile ram error m output module 2 
unsigned MemBlkErr : 1; // 10% or more of image memory is bad 

} IMS errors, 



/•* 



Printer Status object typedefs and class definition 
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class Printer { 
public: 

Printer(void); 

void clear(void); 

int id, 

int SheetsRemaining; 
FILMTYPE MediaType, 
FELMSIZE MediaSize; ' 
int ImgPixels; 
int ImgLines; 
Quality quality; 
PR_type type, 
PRstatus status; 
PRwarnings warnings; 
PR_errors errors 

}; 

typedef struct { 
unsigned Warnings: 1; 
unsigned Errors : 1; 
} PR_status, 
typedef enum { 
Draft, 
Photo 
} Quality; 
typedef enum { 
SpectrumPR, 
AntaresPR, 
LT_SE154^PR > 
NoJPR, 
XLJ>R 
} PRjype; 
typedef struct { 
unsigned MediaLow : ], 
unsigned Busy : 1 



unsigned PrCalib : 1 ; 
) PR warnings; 
typedef struct { 

unsigned BadCass : 1; 

unsigned CassErr : 1 ; 

unsigned CassJam : 1, 

unsigned CoverOpen : 1 ; 

unsigned ExpJam : 1, 

unsigned MediaOut : 1 ; 

unsigned NoCass ; 1 ; 

unsigned PanelErr : 1, 

unsigned PrDown ; 1; 

unsigned RecMagFull : 1; 



// Constructor 

// clears status object 

//Printer Id 

// # of sheets left 

//Type of film loaded 

// Size of film loaded 

//# of imageable pixels 

// # of imageable lines in media 

// Current quality condition 

// Printer Type 

// Printer status flags 

// current warnings in Printer 

// current errors in Printer 



// Warnings exist in the system 
// Errors exist in the system 



// Spectrum printer. 
// Antares printer 
// LT printer 
// No printer connected 
// XL (Roadrunner) printer 

// Media is low (less than 20 sheets). 
// The printer has a transient problem. 
// Primer is generating a calibration sheet. 

// Media cassette is inoperable. 

// Cassette error occurred 

// Media jam at cassette 

// One of the covers is open 

// Media jam at exposure point 

//No media in printer. 

// No media cassette in printer 

// Printer LCD panel in non operable 

// Printer is not operational 

// The Rec Magazine is full and needs to be emptied. 
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unsigned RecMagMiss 
unsigned ToExpJam : 
unsigned ToProcJam : 
} PR_errors; 



// The Receive Magazine is not in the printer 
// Media jam transporting to exposure point. 
//Media jam transporting to film processor. 



/** Job Status object typedefs and class definition 
class Job { 
public: 

Jotyvoid), 

void clean^void), 

int id, 

int PrintsComplete; 
int PrintsFailed; 
int PrintsQueued; 
int FilmsCompIete, 
int FilmsFailed, 
int FilmsQueued, 
JOB_status status; 
JOB_errors errors, 

}; 

typedef struct { 

unsigned Done : 1 ; 

unsigned Killed : 1, 

unsigned Stopped : 1 ; 

unsigned Wait : 1, 

unsigned Errors : 1; 
} JOB status; 
typedef struct { 

unsigned Aborted : 1, 

unsigned BadBand : 1 ; 

unsigned BadMedia : 1; 

unsigned BadTable : 1 ; 

unsigned CrossPrtErr : 1 ; 

unsigned FPErr : 1 ; 

unsigned ImgAbut : 1; 

unsigned IMSErr : 1; 

unsigned LinePixelErr : 1 ; 



// Constructor 
// clears status object 
//JOB Id 

// # prints printed properly 
// # prints printed improperly 
// # prints waiting to be printed 
// # sheets printed properly 
// U sheets printed improperly 
// # sheets waiting to be printed 
// JOB status 
// current errors in JOB 



// Job is complete 
// Job was killed 
// Job was stopped 
// Print is in print queue 
// Job has errors 



unsigned MaxBadCnt 
unsigned MaxBandlmg 
unsigned MaxHorlmg 
unsigned MinBand 
unsigned Parity : 1 ; 
unsigned PrErr ; 1 ; 
unsigned RecMagErr 
unsigned WrongQual 
} JOBerrors; 



// Abort command issued 
// Images not contained in a single band 
// Media not available 
// Invalid table specified 
// Illegal configuration' 
// Film processor has failed 
// Images illegally abut each other 
// Images illegally abut each other 
// Too many pixels 
// Two identical errors 
: 1 ;// max images per band 
: 1 ; // max horizontal images 
; // Fewer than min lines per band 
// Parity error within an image 
// Printer has failed 
1; // Receive Magazine missing or full. 
1; // Quality not available 
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/** Transfer Job Status 

class Xfr { 

public: 

Xfr(void), 

void clear(void) t 

int id, 

Length Xsize; 
Length Y_size, 
XFRstatus status; 
XFR_errors errors; 

}; 

typedef int Length; 
typedef struct { 

unsigned Wait : 1, 

unsigned Done : 1 ; 

unsigned Killed : 1; 

unsigned Errors : 1; 
} XFR status; 
typedef struct { 

unsigned Aborted : 1 ; 

unsigned AcqErr : 1 ; 

unsigned BadDepth : 1; 

unsigned BadMode : 1, 

unsigned ConnectErr : 1 ; 

unsigned EibParamErr : 1 ; 

unsigned EibSrcErr : 1 ; 

unsigned EibTranErr : 1 ; 

unsigned FifoErr : 1 ; 

unsigned MemBoundErr ; 1 



object typedefs and class definition 



// Constructor 

// clears status object 

//JOB Id 

// Horizontal image size (if job complete) 
// Vertical image size (if job complete) 
// JOB status 
// current errors in JOB 



// Job is in queue 
// Job is complete 
// Job was killed 
// Job has errors 



unsigned MemErr 
unsigned MemFull 
unsigned NVRamErr 
unsigned ParityErr : 
unsigned ResErr 
unsigned SetUpErr 
unsigned SizeErr 
unsigned TimeOut 
} XFRerrors; 



1; 



: i; 
: 1; 

1; 
1; 

: i; 
i; 
: 1; 



// Abort command issued 

// Acquisition error 

// The depth specified cannot be set. 

// Incorrect current mode. 

// Connection error 

// Bad parameter in NVRAM 

// Bad source value in NVRAM 

// Error while translating EIB parameters 

// FIFO overflow 

; // Outside boundary of available memory 
// Memory error during store 
// Image memory is full 
// Misc error with NVRAM 
// Parity error 

// store to reserved memory failed 
// Configuration error 
// Image size error 

// System timed out during image store 



The output interpreter component 24, in this embodiment, provides fifteen 
types of remote procedure calls. With the use of the above described imaging objects 
and the remote procedure calls, the client can fully operate output imaging device 1 8. 
Note that all of the parameters contained in the imaging objects described above are 
initialized to an "unassigned value". If the parameter is not changed by the client, the 
output interpreter component 24 will ignore it. This feature allows the client to use 
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only the parameters that it needs. Each of the remote procedure calls provided by 
output interpreter component 24 is described below. Unless otherwise indicated, the 
return for each of the following remote procedure calls is a Laser Imager Response 
Object of type LI response, which will be further described later in this disclosure. 
5 1. Media Print RPCs 

a print Parameters: Type: 

copies (opt) int 
The above RPC initiates a general print from a laser imager functioning as output 
imaging device 18. The above RPC is designed to be used with fixed-formatting 
10 The format is a currently selected fixed format. Copies is an optional parameter 
indicating the number of copies to produce. The images that have been acquired 
since the last print will be used for the print. 

b print Parameters: Type 

format int 

15 image list LIST 

copies (opt) int 

density (opt) int 

destination (opt) DESTINATION _ 

The above RPC initiates a print from the laser imager. Format is the format ID to 
use. Image list indicates which images to use to fill the format Copies is an optional 
parameter indicating the number of copies to produce. Density is an optional integer 
which is used when a density test patch is desired. The integer value corresponds to 
an image ID. Destination is an optional parameter that defines a destination for the 
output rather than the default. 
25 c. print_test Parameters: Type: 

format int 
image list LIST 
densjd IMAGEJD 
copies (opt) int 

30 destination (opt) DESTINATION 

The above RPC initiates a print from the laser imager. Format is the format ID to 
use. Image list indicates which images to use to fill the format Densjd is an integer 
that represents the image id of a density test patch Copies is an optional parameter 
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indicating the number of copies to produce Destination is an optional parameter 
which defines a destination for the output rather than the default 
d a bort Parameters Type 

job ID JOB ID 

5 The above RPC aborts a job having the corresponding id 
e abort Parameters Type: 

none n/ a 
The above RPC aborts all jobs that have been started. 
2 Formattin g RPfs 
10 a define Parameters: Type 

format object FORMAT 
The above RPC defines a format with the exact parameters as found in the format 
object. All parameters equal to NOT ASSIGNED are not included in the definition. 
b defir >e Parameters Type: 

box object BOX 
The above RPC defines a box with the exact parameters as found in the box object 
All parameters equal to NOT_ASSIGNED are not included in the definition 

c. modify Parameters Type: 
box object BOX 

The above RPC modifies the box that matches the id specified in the box object All 
parameters equal to NOTASSIGNED in the box object are not modified. 

d. modify Parameters Type: 

box object BOX 
x _ sh »ft LENGTH 
y_ sh 'ft LENGTH 
The above RPC modifies the box that matches the id specified in the box object The 
location of the box is shifted by the amounts specified in x_shift and y_shift. All 
parameters equal to NOT AS SI GNED in the box object are not modified. 

e. modify Parameters Type: 
format object FORMAT 

The above RPC modifies the format that matches the id specified in the box object 
All parameters equal to NOT ASSIGNED in the format object are not modified. 
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f. remove Parameters: Type: 

none n/a 
The above RPC deletes the last image acquired. 

g. remove Parameters: Type: 

5 box object BOX 

def(opt) Bool 
all (opt) Bool 

The above RPC deletes the box with an id matching that of the received BOX object 

DEF is an optional parameter that when set to TRUE causes the job to be deferred 

10 and processed in the background. If not received, DEF is set to FALSE ALL is an 

optional parameter that when set to TRUE causes all defined boxes to be deleted If 

not received, ALL is set to FALSE 

h remove Parameters Type: 

format object FORMAT 
IS def(opt) Bool 

all (opt) Bool 

The above RPC deletes the format with id matching that of the received FORMAT 

object. DEF is an optional parameter that when set to TRUE causes the job to be 

deferred and processed in the background If not received, DEF is set to FALSE 

20 ALL is an optional parameter that when set to TRUE causes all defined formats to be 

deleted If not received, ALL is set to FALSE. 

i remove Parameters: Type: 

image object IMAGE 
def (opt) Bool 
25 all (opt) Bool 

The above RPC deletes the image with id matching that of the received IMAGE 

object. DEF is an optional parameter that when set to TRUE causes the job to be 

deferred and processed in the background If not received, DEF is set to FALSE 

ALL is an optional parameter that when set to TRUE causes all defined images to be 

30 deleted If not received, ALL is set to FALSE. 

j remo veal 1 Parameters Type: 

def (opt) Bool 
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The above RPC deletes all images, boxes, formats and tables defined in the laser 
imager. DEF is an optional parameter that when set to TRUE causes the job to be 
deferred and processed in the background. If not received, DEF is set to FALSE 
h. remove_fixedJmages Parameters Type: 

none n/ a 
The above RPC deletes all images stored via fixed format store RPCs 
3 Image Manipulation RPCs 

a store Parameters Type 

none n/ a 
This remote procedure call is strictly used with fixed formatting This remote 
procedure call acquires the next image into the next available fixed image location 
The locations range from 1 to N where N is the format specific 
b store Parameters: Type: 

'd FIXEDJD 
This remote procedure call is strictly used with fixed formatting This remote 
procedure call acquires the next image into the location specified by id The 
locations range from 1 to N were N is the format specific 
c store Parameters Type: 

image IMAGE 
The above RPC acquires the next image. The return information regarding image 
size is placed in LI response. 

d store Parameters: Type: 

ima ge TESTJMAGE 
The above RPC acquires the next image as a test pattern The return information 
25 regarding image size is placed in LI_response 

e st ore Parameters Type: 

stnng STRING 
The above RPC stores the text and the id in the STRING object This allows the 
client component to recall the text at any time via the id. The return information 
30 regarding string size is placed in LI_response 

f transfer Parameters- Type: 
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image IMAGE 
The above RPC transfers the next image as a background job. The return 
information regarding image size is available when image transfer is complete 
g. reserve Parameters: Type: 

5 image IMAGE 

The above RPC allocates enough image memory to hold the image described by the 
IMAGE object. 

4 Process Configuration / Status RPC 

a. set Parameters: Type: 

1 0 parameter object PARAMETER 

The above RPC sets the imaging parameters for the laser imager. All parameters set 
to NOT ASSIGNED will be left unchanged. 

5 Status RPCs 

a. show Parameters: Type: 

15 parameter object 'PARAMETER 

The above RPC retrieves the imaging parameters for the laser imager 

b. showfixed Parameters: Type 

parameter object *PARAMETER 
The above RPC retrieves the fixed formating imaging parameters for the laser imager 
20 All other members in the parameter object are left unchanged. All other members in 
the parameter object are left unchanged. 

c show mem Parameters: Typ e 

parameter object 'PARAMETER 
The above RPC retrieves the memory conditions of the laser imager. 
25 d show Parameters: Type: 

image object * IMAGE 

The above RPC retrieves the length and width of the image with id matching the id 
given in the image object. All image information is placed in the image object 
e show Parameters: Type: 

30 printer object 'PRINTER 
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The above RPC retrieves the status of the printer with id matching the id given in the 
printer object All printer information is placed in the printer object, 
f show Parameters Type: 

job object *JOB 
5 The above RPC retrieves the status of the job with id matching the id given in the job 
object. All job information is placed in the job object 

g show Parameters: Type: 

printer object *XFR 
The above RPC retrieves the status of the transfer job with id matching the id given 
10 in the transfer job object. All transfer job information is placed in the transfer job 
object. 

h showformats Parameters Type: 

string * c har 
The above RPC retrieves a string of id's of the defined formats. 
15 » show images Parameters: Type: 

string *char 
The above RPC retrieves a string of id's of the acquired images 

j. show con tables Parameters: Type: 

string *char 
20 The above RPC retrieves a string of id's of the defined contrast tables 
k show_con_tabIes Parameters Type: 

string * c har 
The above RPC retneves a string of id's of the defined color contrast tables 
1. setdebugjevel Parameters Type: 
25 debug level DEBUG_LEVEL 

Returns: Type: 
Driver return code DRIVERRC 
The above RPC allows the client component to set the debug level of network 
interpreter component 32. The debug levels are NODEBUG, LOW DEBUG, 
30 MEDIUMJDEBUG, and HIGHDEBUG This parameter affects the information 
displayed during debugging. 
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One advantage of the interface to output interpreter component 22 is that 
every remote procedure call returns a similar object This object is called, most 
appropriately, the laser imager response object, as indicated above. Within the laser 
imager response object is a plethora of information regarding the result of the remote 
5 procedure call. However, the client may choose to examine only the information 
relevant to its needs. The laser imager response object has three main fields The 
first is a simple boolean value entitled success The boolean value reflects whether 
the request associated with the remote procedure call was accomplished or whether it 
failed. This information may satisfy the needs of most client components The 
second field, success_data, returns any values that the client component expects if the 
command was successful. Normally, there will not be any information for a 
successful command. However, one example of information returned for a successful 
command would be the image size that is returned after a successful store image 
command. The third field, errors, is used to explain why the remote procedure call 
failed. This field is actually a comprehensive bit field of errors that the laser imager 
may incur. Again, this field is only valid if success is false. 

The C++ code listed below describes the laser imager response object. The 
class defines the response received from the laser imager after a command has been 
issued. If the command executed successfully, the SUCCESS flag is set to TRUE. 
20 Any data that is received upon a successful completion will be stored in 

Success Data. If the command failed, the SUCCESS flag is set to FALSE The 
cause of the failure is stored in the Failures structure 

class LI response { 
friend SS_EXECUTIVE; 
25 Command cmd, // SS command 

public: 

Llresponse(void), // constructor 

Bool success, // Command executed to completion 

Success_Data success_data; // Only valid upon successful completion 

30 Failures errors; // If command failed, errors causing failure 

typedef struct { 

unsigned AcqErr : 1 , // Acquistion Error 

unsigned AcqLockout : 1; // Acquistion never attempted, not available 

35 unsigned BadBoxId : 1 , // Box ID does not exists for modification 

unsigned BadDepth : 1; // p ixe | depth error 
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unsigned BadFmtld 
unsigned BadPar ; I; 
unsigned BadCConTbl 
unsigned BadCMediaTbl 
unsigned BadConTbl 
unsigned BadCMixTbl 
unsigned BadDensTest 
unsigned BadDest ; 1; 
unsigned Badlmgld 
unsigned BadJobld 
unsigned BadMedia 
unsigned BadMode 
unsigned BoxInUse : 1 
unsigned Busy : 1; 
unsigned CConlnUse 
unsigned ConlnUse 
unsigned ConnectErr 
unsigned EibParamErr : 1 ; 
unsigned EibSrcErr : 1; 
unsigned EibTranErr : 1; 
unsigned Empty : 1; 
unsigned FifoErr : 1, 
unsigned FmtFull : 1 ; 
unsigned FmtlnUse : 1; 
unsigned FmtOvrLap : 1; 
unsigned FmtOflSheet : 1 ; 
unsigned FmtTMCon 
unsigned FmtTMCCon 
unsigned FmtTMCMix : 1 
unsigned FmtTMCMedia : 
unsigned FmtTMlmgs 
unsigned Full : 1 ; 

unsigned InModlnUse : 1 ; 



l; 



unsigned ImglnUse ; 1; 
unsigned Imglnvalid : 1; 
unsigned JobDone : 1; 
unsigned MagErr : 1 ; 
unsigned MaxFmts : 1 ; 
unsigned MaxJobs : 1; 
unsigned MemBoundErr : 
unsigned MemErr : I; 
unsigned MemFull ; 1; 
unsigned MissPar : 1; 
unsigned MovErr ; 1; 
unsigned NoMem : 1; 
unsigned NVRamErr : 1 ; 
unsigned ParityErr : 1 ; 



: 1; // Format ID does not exist 

// Bad Parameter 
: 1 ; // Bad Color Contrast Table 
: 1 , // Bad Color Media Table 
: 1; //Bad Contrast Table 
: 1 ; // Bad Color Mixing Table 
: 1; // Image is not a valid density test patch 

// Invalid destination 
: 1 ; // Image was not found 
: 1 ; // Job was not found 
: 1; // Media type correct 
: 1; // Incorrect input mode (color / b&w) 
// Box is currently being used 
// Module is already doing an image transfer 
// Color Contrast table currently being used 
// Contrast table is currently being used 
// Hardware connection problem 
// EIB parameter error 
// Invalid EIB source 
// EIB transfer parameters invalid 
// Mbox is currently empty 
// FIFO overflow 

// would be more than 255 boxes in a format 
// Format currently being used 
// The boxes in this format overlap 
// box in this format will not fit on media 
: 1 ; // Too many contrast tablesin this format 
: I; // Too many color cont tables in this format 
; // Too many color mix tables in this format 

1; // Too many color med. tables in this format 
: 1; // Too many images specified in image list 
// MBOX is full 

// Input Module is currently being used 
// Image is currently being used 
// Image has not been fully stored yet 
// Job has already terminated 
// Magnification error 
// There would be more than 255 formats 
// Would exceed max U concurrent jobs 
1, // Invalid image memory address 

// Memory error occured during store 
// Image Memory is full 
// Missing Parameter 

// Move would cause box location to become neg 
// Not enough memory to execute command 

// Problem with the Non Volatile memory 
// Hardware parity error 
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unsigned 
unsigned 
unsigned 
unsigned 
unsigned 
unsigned 
unsigned 
unsigned 
unsigned 
unsigned 
unsigned 
} Failures; 



PassErr 



QueueFull : 1; 
ResErr : 1, 
SetUpErr : I; 
SizeErr : 1; 
StoErr : I; 
TimeOut : 1; 
TooLong : 1; 
Unkillable : 1; 
UnknownCmd : 
WinErr : ]: 



// Double pass required, single pass module 
// Print Queue full. No more jobs possible. 
// Image size did not match reserved memory 
// Request does not match system configuration 
// Size in Img Header does not match image size 
// Video or Digital signal error during acquisition 
// Image acquistion could not be completed 
// Message is too long to fit in the mbox 
// Job(s) cannont be killed 
1 , // Unknown command issued 
// Window specified is incorrect size 
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The following structure holds data that input imaging device 18 (the laser imager) 

returns if the command executes correctly. Thus, this data is only valid if no errors 

occurred during execution. 

typedef struct { 
ID id; 

LENGTH x_size; 
LENGTH ysize, 
LIST list, 
} Success_Data, 



// Place holder for a return ID 
// Place holder for an Image size 
// Place holder for an Image size 
// Place holder for an ID list 
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The actual base class for output interpreter component 24 can be defined in C++ as 
follows: 

class LI INTERF ACE { 
public: 

LI_INTERFACE(PORT_ID newjd, OUTPUTINTERFACE *p) //constructor 
-LI_INTERFACE(void); 



INT32 return code; 
DRIVER RC out_driver_rc, 
DEBUGLEVELS debug level, 
Semaphore rpc reply; 
Semaphore rpc free; 
Semaphore eventreply; 
Semaphore event free, 
PORTJD execjd; 
Mailbox rpc mbox; 
Mailbox event_mbox; 



// RC for OS operations 
// RC from output driver 
// Debug level for module 
// RPC response complete 
// RPC mailbox free 
// async event received 
// async event mailbox free 

// RPC mailbox 
// event mailbox 



40 OUTPUT INTERFACE 'output handle, 

FEPTR client; // c |i en t module using us 

FE_METHOD_PTR client^async_handler; // pointer to async handier 
virtual Bool output^ev Jiandler(enum IO EVENT event) =0 

//asynch event handler 
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virtual void set_async Junc(FE_PTR,FE_METHOD_PTR)-0; 

//set ptr to FE handler 

/*** Laser Imager Client Interface ***/ 
// Basic Transparent Command 
5 virtual LI_response send(char *); //send generic text 

virtual LIresponse receive(char *); //receive generic text 
// Print Commands 

virtual LI response print(int copies=l)=0, //Fixed format print 
virtual LI response print(FORMAT_ID id,LIST "images, 
10 int copies=l, DESTINATION d=FiIm_Processor_l)=0; 

virtual LI response print jest(FORMAT_ID id,LIST * images, 
IMAGE_ID dens Jd,int copies= 1 , 
DESTINATION d=Film_Processor l)=0, 
virtual LI response abort(JOB_ID id^O, 
1 5 virtual LI response abort(void)=0, //Abort all jobs 

// Formatting Commands 

virtual LI_response define(BOX box)=O l //Define a box 

virtual LI response define(FORMAT format)=0, //Define a format 

virtual LI response modify(BOX box)=0; //Modify a box 

virtual LI response modify(LENGTH XSHIFT, LENGTH Y SHIFT BOX 
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box)=0, 

virtual LI response modify(FORMAT format)=0, //Modify a format 
virtual LI_response remove(FIXEDJD); //Remove image from a position 
25 virtual LIresponse remove(BOX box,Bool def=FALSE,Bool ali=FALSE), 

//Del box 

virtual LI_response remove(FORMAT format,Bool def=FALSE,Bool 
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all=FALSE); 

virtual LI_response remove(IMAGE image,Boo! def-FALSE.Bool all=FALSE); 
virtual LI response remove Jixed JmagesCvoid), //Remove all fixed images 
virtual LI_response remove_all(Bool def=FALSE); //Delete everything 
// Manipulation Commands 

virtual LI response reserve(EvlAGE image)=0, //Reserve memory 
35 virtual LIresponse store(void)K); //Store next image 

virtual LI response store(FIXED JD)=0; //Store image for a position 

virtual LI_response store(IMAGE image^O, //Store an image 
virtual LIresponse store(TEST_IMAGE image)=0 ( //Store a test image 
virtual LI__response store(STRING string)-0, //Store a test image 
40 virtual LI response transfer(IMAGE image)=0; //Transfer an image 
// Mailbox Commands 

virtual LI response clear(MAILBOX mbox)=0; //Clear a mailbox 
virtual LI_response receive(MAILBOX mbox,char *msg)=0, 

//Get a msg into a mbox 
45 virtual LI response send(MAILBOX mbox,char *msg)=0; 

n _ //Send a message to a mbox 

// Process configuration / status commands 
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virtual LIresponse set(PARAMETERS ptr)=0, //set imaging parameters 
virtual LI response show_flxed(PARAMETERS *); 

virtual LI_response show_mem(PARAMETERS *ptrj, //show image memory 
virtual LI response show(PARAMETERS *ptr)=0, //show imag params. 
5 virtual LI_response show(IMAGE *ptr)=0, //show info of image 

virtual LIresponse show(Film_Processor *ptr)=0; //show status of a FP 
virtual LI response show(Image_Mgmnt_System *ptr)=0, //show IMS status 
virtual LI response show(Printer *ptr)=0; //show status of Printer 

virtual LI response show(Job *ptr)=0; //show status of a Job 

1 0 virtual LI response show(Xfr *ptr)=^0; //show status of Xfr job 

virtual LI response show_formats(char •ptr^O, //string of defined frmts 
virtual LI response show_images(char *ptr)=0, //string of defined images 
virtual LI_response show_conJab!es(char *ptr)=0, //string of cont tables 
virtual LI_response show_cconJables(char *ptr)=0, //string of color con tbls 

15 }; 

The Output Driver Base-Class Protocol 

The output driver component 24 provides five remote procedure calls for 
output interpreter component 22. With the five remote procedure calls, output 
20 interpreter component 22 can directly interface with an output imaging device 18, 
such as a laser imager. Each of the five remote procedure calls is described below: 

1 . xmitmessage Parameters: Type: 

message char * 

25 Returns: Type: 

Driver return code DRIVERRC 

The above RPC passes output driver component 24 a message to transmit to input 
imaging device 12 via pipeline 30. The output driver component 26 handles all 
30 requirements for communication with output imaging device 1 8 

2. receive_message Parameters Type: 

message char * 

Returns: Type 
Driver return code DRIVER RC 
35 The above RPC retrieves a message from output driver component 26 that has been 

sent from output imaging device 18. Again, output driver component 26 handles all 

requirements for communication with output imaging device 

3. setxmitjimeout Parameters: Type: 
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timeout int 
Returns: Type: 
Driver return code DRIVER_RC 
The above RPC sets the timeout value that output driver component 26 should use 
when sending to the output imaging device 18. 

4. set_async_func Parameters Type: 

client ptr FECLIENTPTR 
method ptr FE_METHOD_PTR 

Returns: Type: 

Driver return code DRIVER RC 

The above RPC gives output driver component 26 a handle to the asynchronous 

handler of the client component, output interpreter component 24. The above RPC is 

used to inform the client component of asynchronous events that have occurred. The 

only event is MSG PENDING which indicates a message has been fully received 

from output imaging device 18 and is ready for the output interpreter component 24 

5. set_debugjevel Parameters Type: 

debug level DEBUG LEVEL 

Returns: Type: 
Driver return code DRIVER_RC 

The above RPC allows the client component to set the debug level for output driver 
component. The debug levels are NO DEBUG, LOW DEBUG, 
MEDIUMDEBUG, and HIGHDEBUG This parameter affects the information 
displayed during debugging 

As noted above, each RPC returns one of three driver return codes: ( 1 ) 
25 RPCOK. (2) PORTJJUSY, and (3) NOMESSAGE The driver return codes can 
be defined in C++ code as follows: 

//Set return types for I/O Driver interface 
typedef enum { 
RPC_OK, //RPC was issued and acknowledged 
30 PORT_BUSY, //Transmit RPC failed, port already transmitting 
NO MESSAGE //Receive RPC failed, no message pendine 
} DRIVER RC; 
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The actual base class protocol for output driver component 26 can be defined in C++ 
code as follows. 

class OUTPUT INTERFACE 
{ 

> public: 

OUTPUT_INTERFACE(PORTJD newport) 
~OUTPUT_INTERFACE(void); 
virtual DRIVER_RC xmit_message(char ^message) = 0; 
virtual DRIVERRC receive_message(char *message) =0; 
virtual DRIVERRC set_xmit_timeout(int timeout) =0 
virtual DRJVER_RC set_async_func(CLENT_PTR, 

CL1ENT METHOD PTR) =0 // 
PORT_ID port; //This port ID 

15 As the embodiments of the invention have already been described, additional 

advantages and modifications will readily occur to those skilled in the art from 
consideration of the specification and practice of the invention as is disclosed herein. 
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What is claimed is 

1 . A software system for communicating medical image information 
between at least one of a plurality of different medical imaging modalities (12) and at 
least one of a plurality of different laser imagers (1 8) via a network interface (28), the 
5 software system comprising: 

one or more network interface components (33), each of the network 
interface components being configured to receive medical image information from 
one of the medical imaging modalities via the network interface, the medical image 
information being received according to one of a plurality of different network 

10 interface protocols, wherein each of the network interface protocols is specifically 
associated with one of the medical imaging modalities, and to generate first imaging 
requests based on the received medical image information, the first imaging requests 
being generated according to the one of the network interface protocols, 

one or more output interface components (16), each of the output interface 

15 components being configured to generate second imaging requests based on the first 
imaging requests generated by one of the network interface components, the second 
imaging requests being generated according to one of a plurality of different output 
interface protocols, wherein each of the output interface protocols is specifically 
associated with one of the laser imagers, and to communicate the second imaging 

20 requests generated by one of the output interface components to one of the laser 
imagers, the second imaging requests being communicated according to the one of 
the output interface protocols, and 

an interface executive component (20) for defining one or more 
communication pipelines (26), each of the pipelines communicatively interconnecting 

25 one of the medical imaging modalities, one of the network interface components, one 
of the output interface components, and one of the laser imagers 

2 The software system of claim 1 , wherein each of said network 
interface components includes a first interface for communicating the first imaging 
requests to one of said output interface components according to a base-class 

30 protocol generic to each of said network interface components and understood by 
each of said output interface components 
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3 The software system of claim 2, wherein the base-class protocol is 
defined according to an object-oriented hierarchy. 

4. The software system of claim 2, wherein: 

each of said output interface components is further configured to receive first 
5 responses to the second imaging requests from one of said laser imagers, said first 
responses being received according to one of said output interface protocols, and to 
generate second responses based on said first responses, said second responses being 
generated according to one of said output interface protocols; and 

_ each of said network interface components is further configured to generate 
third responses based on said second responses generated by one of said output 
interface components, said third responses being generated according to one of said 
network interface protocols, and to communicate said third responses to one of said 
input imaging devices, said third responses being communicated according to one of 
said network interface protocols; and 
1 5 each of said pipelines defined by said interface executive component is a bi- 

directional pipeline communicatively interconnecting one of said input imaging 
devices, one of said network interface components, one of said output interface 
components, and one of said laser imagers for bi-directional communication between 
one of said medical imaging modalities and one of said laser imagers 
20 5 - The software system of claim 4, wherein each of said output interface 

components includes a second interface for communicating the second responses to 
one of said network interface components according to a second base-class protocol 
generic to each of said output interface components and understood by each of said 
network interface components. 
25 6 The software system of claim 4, wherein said interface executive 

component defines each of said pipelines according to a client -server relationship 
such that each of said network interface components is a client of one of said output 
interface components, and said interface executive component is a client of each of 
said network interface components 
30 7 ^ software system of claim 6, wherein communication between said 

network interface components and said output interface components is carried out by 
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remote procedure calls generated by said network interface components and executed 
by said output interface components, and wherein communication between said 
interface executive component, said network interface components, and said output 
interface components is carried out by remote procedure calls generated by said 
> interface executive component and executed by said network interface components. 

8. A device for imaging medical information communicated by one or 
more clients (12) on a network, comprising: 

network executive means (14) for, in response to receiving an imaging 
request from a client, generating a corresponding first imaging request; 

output interface means (16) for, in response to receiving the corresponding 
first imaging request from the network executive means, generating a corresponding 
second imaging request for transmission to the imaging device (18); and, 

interface executive means (20) for instantiating the network executive 
component according to an input protocol spoken by the client and the output 
1 5 interface component according to an output protocol spoken by the imaging device 

9. The device of claim 8, wherein the network executive means 
instantiates: 

network driver means (30) according to a network driver protocol of the 
input protocol, for receiving from the client the imaging request; and, 
20 network interpreter means (32) according to a network interpreter protocol 

of the input protocol, for generating the corresponding first imaging request 

10. The device of claim 7, wherein the output interface means comprises: 
output interpreter means (22) specific to an output interpreter protocol of the 

output interpreter protocol, for receiving the first imaging request from the network 
25 executive component and generating the corresponding second imaging request; and, 
output driver means (24) specific to an output driver protocol of the output 
protocol, for transmitting the corresponding second imaging request to the imaging 



device. 
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